backend

backend

Rust开发的模块化通讯后端框架

Revolt Backend是一个基于Rust语言的开源通讯后端框架。采用monorepo结构管理核心配置、数据库、API模型和权限逻辑等多个组件。框架提供REST API和WebSocket事件服务,支持用户在线状态管理。其模块化设计便于开发者部署和定制,适用于构建高性能、可扩展的实时通讯应用。

Revolt BackendRust微服务架构开源项目实时通信Github

Revolt 后端

这是 Revolt 后端的单一代码库。

路径描述
core/configcrates/core/config核心:配置
core/databasecrates/core/database核心:数据库实现
core/modelscrates/core/models核心:API 模型
core/permissionscrates/core/permissions核心:权限逻辑
core/presencecrates/core/presence核心:用户在线状态
core/resultcrates/core/result核心:结果和错误类型
deltacrates/deltaREST API 服务器
bonfirecrates/bonfireWebSocket 事件服务器

注意:januaryautumnvortex 尚未移入此单一代码库。

最低支持的 Rust 版本

Rust 1.76 或更高版本。

开发指南

在贡献之前,请熟悉我们的贡献指南本项目的技术文档

在开始之前,你需要安装:

  • Rust 工具链(推荐使用 rustup)
  • Docker
  • Git
  • mold(可选,加快编译速度)

Nix 用户可以使用 default.nix! 只需运行 nix-shell 并继续。

现在你可以克隆并构建项目:

git clone https://github.com/revoltchat/backend revolt-backend cd revolt-backend cargo build

如果你想运行 API 和事件服务器:

# 创建环境文件(未来将被弃用) cp .env.example .env # (可选)复制默认配置文件 cp crates/core/config/Revolt.toml Revolt.toml # 根据需要进行配置...

你可能想复制以下配置:

# Revolt.toml [database] mongodb = "mongodb://localhost" redis = "redis://localhost" [hosts] app = "http://local.revolt.chat" api = "http://local.revolt.chat:8000" events = "ws://local.revolt.chat:9000" autumn = "http://local.revolt.chat:3000" january = "http://local.revolt.chat:7000" voso_legacy = "" voso_legacy_ws = ""

然后继续:

# 启动其他必要的服务 docker compose up -d # 运行 API 服务器 cargo run --bin revolt-delta # 运行事件服务器 cargo run --bin revolt-bonfire # 提示: # mold -run <cargo build, cargo run, 等...>

你可以通过以下方式启动 Web 客户端:

# 如果你还没有 yarn 并且有最新版本的 Node.js: corepack enable # 克隆 Web 客户端并运行它: git clone --recursive https://github.com/revoltchat/revite cd revite yarn yarn build:deps yarn dev --port 3001

然后访问 https://local.revolt.chat:3001

部署指南

发布新的包版本

首先升级包版本:

just patch # 0.0.X just minor # 0.X.0 just major # X.0.0

然后提交对包文件的更改。

继续发布所有新的包:

just publish

发布新的二进制版本

通过运行以下命令标记并推送新版本:

just release

如果你已升级包版本,请前往 GitHub releases 创建更新日志。

测试

首先,启动所需的服务:

docker compose -f docker-compose.db.yml up -d

现在为任意数据库运行测试:

TEST_DB=REFERENCE cargo nextest run TEST_DB=MONGODB cargo nextest run

许可证

Revolt 后端通常根据 GNU Affero 通用公共许可证 v3.0 授权。

各个包可能提供自己的许可证!

编辑推荐精选

TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
商汤小浣熊

商汤小浣熊

最强AI数据分析助手

小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。

imini AI

imini AI

像人一样思考的AI智能体

imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。

下拉加载更多