部署指南
本指南涵盖 DeerFlow 应用所有支持的部署方式:本地开发、Docker Compose 以及使用 Kubernetes 管理沙箱的生产环境。
本地开发部署
本地工作流是运行 DeerFlow 最快的方式,所有服务作为原生进程在你的机器上运行。
启动
make dev启动的服务:
| 服务 | 端口 | 描述 |
|---|---|---|
| Gateway API | 8001 | FastAPI 后端 + 嵌入式 Agent 运行时 |
| 前端 | 3000 | Next.js 界面 |
| nginx | 2026 | 统一反向代理 |
Docker Compose 部署
Docker Compose 在容器中运行所有服务。适用于更接近生产的本地设置或团队环境。
前置条件
- Docker(macOS 上的 Docker Desktop 或 OrbStack)
- 在仓库根目录中已配置的
config.yaml
开发 Compose
# 设置 deer-flow 仓库根目录的绝对路径
export DEER_FLOW_ROOT=/path/to/deer-flow
docker compose -f docker/docker-compose-dev.yaml up --build环境变量
在仓库根目录创建 .env 文件用于存放密钥和运行时配置:
# .env(项目根目录 — Gateway、API Key、认证)
OPENAI_API_KEY=sk-...
AUTH_FRONTEND_BASE_URL=https://your-domain.com
AUTH_JWT_SECRET=... # 可选;未设置时写入 .deer-flow将 frontend/.env.example 复制为 frontend/.env 配置界面品牌名(NEXT_PUBLIC_APP_NAME 等)。
docker-compose*.yaml 为 gateway 加载 ../.env,为 frontend 加载 ../frontend/.env。
数据持久化
线程数据存储在 backend/.deer-flow/threads/。在 Docker 部署中,此目录会绑定挂载到 gateway 容器中。
为避免容器重建时数据丢失:
- 将
DEER_FLOW_ROOT设置为仓库根目录的绝对路径。 - 验证
threads/和skills/目录挂载正确。
对于生产环境,使用命名卷或持久化卷声明(PVC)代替主机绑定挂载。
生产部署注意事项
沙箱模式选择
| 沙箱 | 使用场景 |
|---|---|
LocalSandboxProvider | 单用户、受信任的本地工作流 |
AioSandboxProvider(Docker) | 多用户、中等隔离需求 |
AioSandboxProvider + K8s Provisioner | 生产环境、强隔离、多用户 |
对于有多个并发用户的任何部署,使用基于容器的沙箱,防止用户之间的执行环境相互干扰。
K8s Provisioner 配置
配置 Provisioner
在你的 .env 或 compose 覆盖文件中设置必需的环境变量:
K8S_NAMESPACE=deer-flow
SANDBOX_IMAGE=enterprise-public-cn-beijing.cr.volces.com/vefaas-public/all-in-one-sandbox:latest
DEER_FLOW_ROOT=/absolute/path/to/deer-flow配置沙箱提供者
# config.yaml
sandbox:
use: deerflow.community.aio_sandbox:AioSandboxProvider
provisioner_url: http://provisioner:8002配置数据持久化
对于生产环境,使用 PVC 代替 hostPath 卷:
# 在 .env 或 compose 环境中
USERDATA_PVC_NAME=deer-flow-userdata-pvc
SKILLS_PVC_NAME=deer-flow-skills-pvc当设置 USERDATA_PVC_NAME 时,Provisioner 自动使用子路径(threads/{thread_id}/user-data),每个线程在 PVC 中获得自己的目录。
nginx 配置
nginx 将流量路由到前端或 Gateway。/api/langgraph/* 会被重写到 Gateway 的 LangGraph-compatible /api/* 路由,因此不需要单独的 LangGraph upstream。
认证配置
会话由 Gateway(JWT Cookie)管理。生产环境在项目根目录 .env 中设置:
AUTH_FRONTEND_BASE_URL— 对外访问地址(如https://your-domain.com)AUTH_JWT_SECRET— JWT 签名密钥(可选;未设置时写入.deer-flow)- OAuth / 魔法链接:
AUTH_*_CLIENT_*、RESEND_API_KEY、RESEND_FROM
# 生成密钥
openssl rand -base64 32资源建议
| 服务 | 最低配置 | 推荐配置 |
|---|---|---|
| Gateway + Agent 运行时 | 2 vCPU、4 GB RAM | 4 vCPU、8 GB RAM |
| 前端 | 0.5 vCPU、512 MB | 1 vCPU、1 GB |
| 沙箱容器(每会话) | 1 vCPU、1 GB | 2 vCPU、2 GB |
部署后验证
启动后验证部署:
# 检查 Gateway 健康状态
curl http://localhost:8001/health
# 通过 nginx 列出配置的模型(验证完整代理链)
curl http://localhost:2026/api/models正常工作的部署会从每个端点返回 200 响应。/api/models 调用会返回你 config.yaml 中的模型列表。