Redwood:构建分布式实时应用的未来

Redwood:构建分布式实时应用的未来

redwood A highly-configurable, distributed, realtime database that manages a state tree shared among many peers. 项目地址: https://gitcode.com/gh_mirrors/redw/redwood

项目介绍

Redwood 是一个高度可配置、分布式的实时数据库,它管理着一个在多个对等节点之间共享的状态树。想象一下,它就像一个分布在所有应用用户之间的 Redux 存储,支持离线编辑,并且能够在网络连接不佳的情况下保持稳定。Redwood 不仅仅是一个数据库,它还是一个应用服务器。开发者可以直接在状态树中存储和更新资产(如 HTML、JavaScript、图像等)。对于许多类型的应用,你可能根本不需要一个单独的后端服务器。

Redwood 的灵活性使得开发者可以使用单一、简单的编程模型来创建多种不同类型的应用,包括传统的 Web 应用、实时协作文档编辑器、点对点加密消息传递、区块链以及类似 Git 的版本控制系统。

项目技术分析

Redwood 是 Braid 项目的一部分,使用 Braid 协议通过常规 HTTP 同步更新。Braid 协议目前正在通过 IETF 的 RFC 流程进行标准化。Redwood 实现了多种传输协议,包括 libp2p、Braid-over-HTTP 和 WebRTC。Go 节点之间通过 libp2p 或 HTTP 进行通信,浏览器节点之间通过 WebRTC 进行通信,浏览器节点与 Go 节点之间通过 HTTP 进行通信。

Redwood 的核心特性包括:

  • 账户/身份和访问控制:使用 ECDSA 非对称加密技术为每个对等节点分配一个去中心化的身份(DID),并提供易于配置的访问控制。
  • 事务模型:每个数据库更新都是一个由发送者签名的交易,可以包含一个或多个补丁。
  • 私有事务和子树:用户可以向单个对等节点或组发送私有的、加密的事务。
  • 合并解析:Redwood 允许开发者为状态树配置多种合并解析器,以应对断电、连接丢失和同时编辑冲突等问题。
  • 资产存储:HTML 和 JavaScript 等资产可以直接存储在状态树中。
  • 传输协议:支持多种传输协议,包括 libp2p、Braid-over-HTTP 和 WebRTC。
  • 客户端:包括 Braid.js、Go HTTP 客户端,以及即将推出的 Go protobuf 客户端。
  • Git 集成:Redwood 可以作为 Git 服务器,支持通过 Git 远程助手插件进行克隆、推送和拉取操作。

项目及技术应用场景

Redwood 的应用场景非常广泛,包括但不限于:

  • 传统 Web 应用:开发者可以直接在 Redwood 中存储和更新应用的前端资源,无需单独的后端服务器。
  • 实时协作文档编辑器:Redwood 的状态树可以支持多个用户同时编辑文档,并实时同步更新。
  • 点对点加密消息传递:Redwood 的私有事务和子树功能可以用于构建安全的点对点消息传递系统。
  • 区块链:Redwood 的分布式特性使其可以用于构建去中心化的区块链应用。
  • 版本控制系统:类似于 Git,Redwood 可以用于构建分布式的版本控制系统。

项目特点

Redwood 的主要特点包括:

  • 高度可配置:Redwood 提供了丰富的配置选项,开发者可以根据需求灵活调整。
  • 分布式:Redwood 的状态树分布在多个对等节点之间,支持离线编辑和网络不稳定情况下的稳定运行。
  • 实时性:Redwood 支持实时更新和同步,适用于需要高实时性的应用场景。
  • 安全性:Redwood 提供了多层次的安全模型,包括身份验证、访问控制和加密传输等。
  • 灵活性:Redwood 支持多种编程语言和传输协议,开发者可以根据需求选择最适合的组合。

Redwood 目前仍处于预 alpha 阶段,但其已经包含了许多令人兴奋的特性,并且正在不断改进和扩展。如果你对 Redwood 感兴趣,可以关注我们的 GitHub 项目板,了解最新的开发进展。

redwood A highly-configurable, distributed, realtime database that manages a state tree shared among many peers. 项目地址: https://gitcode.com/gh_mirrors/redw/redwood

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

温宝沫Morgan

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值