🌲 Redwood:构建分布式实时应用的未来
项目介绍
Redwood 是一个高度可配置、分布式的实时数据库,它管理着一个在多个对等节点之间共享的状态树。想象一下,它就像一个分布在所有用户之间的 Redux 存储,支持离线编辑,并且能够在网络连接不佳的情况下保持稳定。Redwood 不仅仅是一个数据库,它还是一个应用服务器。开发者可以直接在状态树中存储和更新资源(如 HTML、JavaScript、图片等)。对于许多类型的应用,你可能根本不需要一个单独的后端服务器。
Redwood 的灵活性使得开发者可以使用单一、简单的编程模型来创建多种不同类型的应用,包括传统的 Web 应用、实时协作文档编辑器、点对点加密消息传递、区块链以及类似 Git 的版本控制系统。
项目技术分析
Redwood 是 Braid 项目 的一部分,并使用 Braid 协议通过常规 HTTP 同步更新。Braid 协议目前正在通过 IETF 的 RFC 流程进行标准化。Redwood 实现了多种传输协议,包括 libp2p、Braid-over-HTTP 和 WebRTC。此外,Redwood 还支持多种客户端,如 Braid.js、Go HTTP 客户端,以及即将推出的 Go protobuf 客户端。
Redwood 的核心特性包括:
- 账户/身份和访问控制:使用 ECDSA 非对称加密技术为每个对等节点分配一个去中心化的身份(DID),并提供易于配置的访问控制。
- 事务模型:每个数据库更新都是一个由发送者签名的交易,可以包含一个或多个补丁。
- 私有事务和子树:用户可以向单个对等节点或组发送私有、加密的事务。
- 合并解析:Redwood 允许开发者为状态树配置多种合并解析器,以应对断电、连接丢失和同时编辑冲突等问题。
- 资产存储:可以在状态树中存储 HTML 和 JavaScript 等资源。
- Git 集成:Redwood 可以作为 Git 服务器,支持
git clone redwood://mysite.com/git
等操作。
项目及技术应用场景
Redwood 的应用场景非常广泛,包括但不限于:
- 传统 Web 应用:开发者可以直接在 Redwood 中存储和更新应用资源,无需单独的后端服务器。
- 实时协作文档编辑器:Redwood 的分布式特性使其非常适合构建实时协作编辑器。
- 点对点加密消息传递:Redwood 支持私有事务和子树,非常适合构建点对点加密消息应用。
- 区块链:Redwood 的分布式状态管理和事务模型使其成为构建区块链应用的理想选择。
- 版本控制系统:Redwood 的 Git 集成功能使其可以作为类似 Git 的版本控制系统。
项目特点
Redwood 的主要特点包括:
- 高度可配置:Redwood 提供了丰富的配置选项,开发者可以根据需求灵活调整。
- 分布式实时数据库:Redwood 的状态树在多个对等节点之间共享,支持离线编辑和网络不稳定情况下的稳定运行。
- 应用服务器:Redwood 不仅仅是一个数据库,它还是一个应用服务器,可以直接在状态树中存储和更新应用资源。
- 多种传输协议:Redwood 支持多种传输协议,包括 libp2p、Braid-over-HTTP 和 WebRTC。
- Git 集成:Redwood 可以作为 Git 服务器,支持 Git 操作,无需单独设置 Git 服务器。
Redwood 目前仍处于预 alpha 阶段,但其已经包含了许多令人兴奋的特性。如果你对 Redwood 感兴趣,可以关注我们的 Github 项目板 以获取最新的开发路线图。
通过 Redwood,开发者可以轻松构建分布式、实时、高度可配置的应用,无论是传统的 Web 应用还是复杂的区块链系统,Redwood 都能提供强大的支持。快来尝试 Redwood,开启你的分布式应用开发之旅吧!
- CangjieCommunity为仓颉编程语言开发者打造活跃、开放、高质量的社区环境Markdown6710
- redis-sdk仓颉语言实现的Redis客户端SDK。已适配仓颉0.53.4 Beta版本。接口设计兼容jedis接口语义,支持RESP2和RESP3协议,支持发布订阅模式,支持哨兵模式和集群模式。Cangjie32226
- Yi-CoderYi Coder 编程模型,小而强大的编程助手305
- qwerty-learner为键盘工作者设计的单词记忆与英语肌肉记忆锻炼软件 / Words learning and English muscle memory training software designed for keyboard workersTypeScript15.77 K1.48 K
- advanced-javaAdvanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。JavaScript76.1 K19.07 K
- taro开放式跨端跨框架解决方案,支持使用 React/Vue/Nerv 等框架来开发微信/京东/百度/支付宝/字节跳动/ QQ 小程序/H5/React Native 等应用。 https://taro.zone/TypeScript35.52 K4.79 K
- CommunityCangjie-TPC(Third Party Components)仓颉编程语言三方库社区资源汇总252
- Wwindows暂无简介Shell16.14 K1.35 K
- byzer-langByzer(以前的 MLSQL):一种用于数据管道、分析和人工智能的低代码开源编程语言。Scala1.88 K551
- AanacondaAnaconda turns your Sublime Text 3 in a full featured Python development IDE including autocompletion, code linting, IDE features, autopep8 formating, McCabe complexity checker Vagrant and Docker support for Sublime Text 3 using Jedi, PyFlakes, pep8, MyPy, PyLint, pep257 and McCabe that will never freeze your Sublime Text 3Python2.22 K263