首页
/ 🌲 Redwood:构建分布式实时应用的未来

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

2024-09-07 11:12:10作者:冯梦姬Eddie

项目介绍

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

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

项目技术分析

Redwood 是 Braid 项目 的一部分,并使用 Braid 协议通过常规 HTTP 同步更新。Braid 协议目前正在通过 IETF 的 RFC 流程进行标准化。Redwood 实现了多种传输协议,包括 libp2pBraid-over-HTTPWebRTC。此外,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,开启你的分布式应用开发之旅吧!

热门项目推荐
相关项目推荐

项目优选

收起
Python-100-DaysPython-100-Days
Python - 100天从新手到大师
Python
373
72
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
276
72
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
200
47
xzs-mysqlxzs-mysql
学之思开源考试系统是一款 java + vue 的前后端分离的考试系统。主要优点是开发、部署简单快捷、界面设计友好、代码结构清晰。支持web端和微信小程序,能覆盖到pc机和手机等设备。 支持多种部署方式:集成部署、前后端分离部署、docker部署
HTML
5
1
LangChatLangChat
LangChat: Java LLMs/AI Project, Supports Multi AI Providers( Gitee AI/ 智谱清言 / 阿里通义 / 百度千帆 / DeepSeek / 抖音豆包 / 零一万物 / 讯飞星火 / OpenAI / Gemini / Ollama / Azure / Claude 等大模型), Java生态下AI大模型产品解决方案,快速构建企业级AI知识库、AI机器人应用
Java
11
3
gin-vue-admingin-vue-admin
🚀Vite+Vue3+Gin的开发基础平台,支持TS和JS混用。它集成了JWT鉴权、权限管理、动态路由、显隐可控组件、分页封装、多点登录拦截、资源权限、上传下载、代码生成器【可AI辅助】、表单生成器和可配置的导入导出等开发必备功能。
Go
16
3
source-vuesource-vue
🔥 一直想做一款追求极致用户体验的快速开发平台,看了很多优秀的开源项目但是发现没有合适的。于是利用空闲休息时间对若依框架进行扩展写了一套快速开发系统。如此有了开源字节快速开发平台。该平台基于 Spring Boot + MyBatis + Vue & Element ,包含微信小程序 & Uniapp, Web 报表、可视化大屏、三方登录、支付、短信、邮件、OSS...
Java
24
2
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
898
0
madongmadong
基于Webman的权限管理系统
PHP
4
0
cool-admin-javacool-admin-java
🔥 cool-admin(java版)一个很酷的后台权限管理框架,Ai编码、流程编排、模块化、插件化、CRUD极速开发,永久开源免费,基于springboot3、typescript、vue3、vite、element-ui等构建
Java
18
2