【RAGFlow代码详解-29】Docker 部署

Docker Compose 架构

RAGFlow 使用多服务 Docker Compose 设置来编排核心应用程序服务器、可选任务执行程序和支持的基础设施服务。主要部署配置在 docker/docker-compose.yml 1-75 中定义

主要服务配置包括运行状况检查依赖项和 .env 文件中的环境变量注入。可选的 MCP 服务器配置在 docker/docker-compose.yml 10-24 中 作为注释示例提供

服务编排和入口点

容器启动过程由 entrypoint.sh 脚本管理,该脚本通过命令行参数提供灵活的服务配置。该脚本支持多种作模式和组件隔离。


入口点脚本通过环境变量替换 docker/entrypoint.sh 133-141 处理配置模板处理,并管理分布式部署 docker/entrypoint.sh 45-56 的主机 ID 生成

MCP 服务器集成

模型上下文协议 (MCP) 服务器为 RAGFlow 提供外部工具集成功能。它可以通过 Docker 部署启用,并支持自托管和多租户主机模式。

MCP 服务器将 RAGFlow 的检索功能公开为 MCP 工具,ragflow_retrieval 工具支持数据集和文档过滤 mcp/server/server.py 175-203

配置管理

部署配置系统使用基于模板的环境变量替换来生成运行时配置文件。这样可以灵活地进行部署定制,而无需重新构建容器。

配置模板处理可确保在容器启动时正确应用特定于环境的设置 docker/entrypoint.sh 133-141

部署模式

RAGFlow 通过入口点脚本的命令行界面支持多种部署配置,允许组件隔离和扩展场景。

部署模式 描述 命令参数 用例
全栈 启用所有组件(默认) 没有 单节点开发/测试
仅限 API 服务器 没有任务处理的 Web 服务器 --disable-taskexecutor 单独的加工工人
API Server Only 没有 Web 服务器的任务执行器 --disable-webserver --workers=N 分布式处理节点
MCP 服务器 启用 MCP 协议服务器 --enable-mcpserver 外部工具集成
Range Workers 特定工作人员 ID 范围 --consumer-no-beg=X --consumer-no-end=Y 细粒度的工人控制

任务执行工作者使用 jemalloc 进行内存管理 docker/entrypoint.sh 154-158,并通过唯一主机标识符 docker/entrypoint.sh 195-207 支持分布式作

相关推荐
大树883 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠3 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质3 天前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
Inhand陈工3 天前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信
Alsn863 天前
等待学习-学习目录:Docker 容器安全攻防
学习·安全·docker
酣大智3 天前
ARP代理--工作原理
运维·网络·arp·arp代理
shushangyun_3 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
施努卡机器视觉3 天前
SNK施努卡侧滑门锁上滑轮总成自动化装配线,从零件到组件,全流程精密制造方案
运维·自动化·制造
AC赳赳老秦3 天前
用 OpenClaw 搭建服务器故障应急响应系统,自动处理 80% 常见运维故障
android·运维·服务器·python·rxjava·deepseek·openclaw
2601_961875243 天前
决战申论100题2026|最新|范文
linux·容器·centos·debian·ssh·fabric·vagrant