docs/DEPLOYMENT_GUIDE_WITH_AUTH_RPA_zh.md
本指南将帮助您按照正确的顺序启动 AstronAgent 项目的所有组件,包括身份认证、RPA、知识库和核心服务。
AstronAgent 项目包含以下四个主要组件:
Agent系统配置要求
RAGFlow配置要求
RagFlow 是一个开源的RAG(检索增强生成)引擎,使用深度文档理解技术提供准确的问答服务。
启动 RagFlow 服务请运行我们的 docker-compose.yml 文件或 docker-compose-macos.yml 。在运行安装命令之前,请确保您的机器上安装了 Docker 和 Docker Compose。
# 进入 RagFlow 目录
cd docker/ragflow
# 给所有 sh 文件添加可执行权限
chmod +x *.sh
# 启动 RagFlow 服务(包含所有依赖)
docker compose up -d
# 查看服务状态
docker compose ps
# 查看服务日志
docker compose logs -f ragflow
访问地址:
模型配置步骤:
重要配置说明:
docker-compose-gpu.yml 启动在启动 AstronAgent 服务之前,需要配置相关的连接信息。
# 进入 astronAgent 目录
cd docker/astronAgent
# 复制环境变量配置
cp .env.example .env
.env 文件只用于配置服务启动、访问地址、认证、数据库、Redis、对象存储等基础设施参数。RAGFlow、讯飞开放平台、AI Ability Chat、虚拟人能力、星火知识库等业务能力账号不再写入 .env,请在 AstronAgent 启动后登录控制台,通过 平台账号管理 页面配置。
# 进入 astronAgent 目录
cd docker/astronAgent
# 编辑环境变量配置
vim .env
配置 AstronAgent 服务的主机地址:
HOST_BASE_ADDRESS=http://localhost
说明:
localhost 替换为您的域名以下配置不需要写入 .env 文件。启动 AstronAgent 后,登录控制台,在左侧菜单进入 平台账号管理,按卡片填写即可;保存后全局生效,不需要重启容器。如果某个功能依赖对应能力但尚未配置,系统会提示前往平台账号管理配置,不会阻塞系统启动。
讯飞开放平台(内置星火模型、实时语音转写、图片生成等能力会使用):
获取文档详见:https://www.xfyun.cn/doc/platform/quickguide.html
创建应用完成后可能需要购买或领取相应能力的API授权服务量
需要准备并在页面中填写:
PLATFORM_APP_IDPLATFORM_API_KEYPLATFORM_API_SECRETSPARK_API_PASSWORDSPARK_RTASR_API_KEYAI Ability Chat(Agent 内部默认模型接口,OpenAI 协议):
AI_ABILITY_CHAT_BASE_URLAI_ABILITY_CHAT_MODELAI_ABILITY_CHAT_API_KEY虚拟人能力:
SPARK_VIRTUAL_MAN_APP_IDSPARK_VIRTUAL_MAN_API_KEYSPARK_VIRTUAL_MAN_API_SECRET知识库平台:
RAGFLOW_BASE_URL、RAGFLOW_API_TOKEN、RAGFLOW_TIMEOUT、RAGFLOW_DEFAULT_GROUPXINGHUO_DATASET_ID创建知识库时会选择使用 RAGFlow 或 星火知识库,只需要配置实际使用的平台。
获取 RagFlow API Token:
RAGFLOW_API_TOKEN获取星火知识库数据集ID:
星火RAG云服务提供两种使用方式:
如果您更喜欢使用命令行工具,可以通过以下 cURL 命令创建数据集:
# 创建星火RAG数据集
curl -X PUT 'https://chatdoc.xfyun.cn/openapi/v1/dataset/create' \
-H "Accept: application/json" \
-H "appId: your_app_id" \
-H "timestamp: $(date +%s)" \
-H "signature: $(echo -n "$(echo -n "your_app_id$(date +%s)" | md5sum | awk '{print $1}')" | openssl dgst -sha1 -hmac 'your_api_secret' -binary | base64)" \
-F "name=我的数据集"
注意事项:
your_app_id 替换为您的实际 APP IDyour_api_secret 替换为您的实际 API Secret获取到数据集ID后,请在 平台账号管理 - 知识库平台 中填写到 XINGHUO_DATASET_ID。
启动 AstronAgent 服务请运行我们的 docker-compose-with-auth-rpa.yaml 文件。该文件已通过 include 机制集成了 Casdoor和RPA后端 服务,会自动启动 Casdoor,RPA。
# 进入 astronAgent 目录
cd docker/astronAgent
# 启动所有服务(包含 Casdoor, RPA)
docker compose -f docker-compose-with-auth-rpa.yaml up -d
说明:
admin,密码:123AstronAgent 启动后,访问控制台并登录,在左侧菜单进入 平台账号管理。平台账号管理与 应用管理、资源管理 等菜单同级,包含以下四个配置卡片:
PLATFORM_APP_ID、PLATFORM_API_KEY、PLATFORM_API_SECRET、SPARK_API_PASSWORD、SPARK_RTASR_API_KEYAI_ABILITY_CHAT_BASE_URL、AI_ABILITY_CHAT_MODEL、AI_ABILITY_CHAT_API_KEYSPARK_VIRTUAL_MAN_APP_ID、SPARK_VIRTUAL_MAN_API_KEY、SPARK_VIRTUAL_MAN_API_SECRETRAGFLOW_BASE_URL、RAGFLOW_API_TOKEN、RAGFLOW_TIMEOUT、RAGFLOW_DEFAULT_GROUP,以及星火知识库的 XINGHUO_DATASET_ID保存配置后会立即全局生效,系统会自动刷新缓存,不需要重启 AstronAgent 容器。
您可以根据需要在 Casdoor 中创建新的应用和组织,并将配置信息更新到 .env 文件中(已存在默认组织和应用)。
获取 Casdoor 配置信息:
访问 Casdoor 管理控制台: http://localhost:8000
使用默认管理员账号登录:admin / 123
创建组织 进入 http://localhost:8000/organizations 页面,点击"添加",填写组织名称后保存并退出。
创建应用并绑定组织 进入 http://localhost:8000/applications 页面,点击"添加"。
创建应用时填写以下信息:
agent80,使用 http://your-local-ip/callback;如果是其他端口(例如 888),使用 http://your-local-ip:888/callback保存应用后,记录以下信息并与项目配置项一一对应:
| Casdoor 信息项 | 示例值 | .env 中对应配置项 |
|---|---|---|
| Casdoor 服务地址(URL) | http://localhost:8000 | CONSOLE_CASDOOR_URL=http://localhost:8000 |
| 客户端 ID(Client ID) | your-casdoor-client-id | CONSOLE_CASDOOR_ID=your-casdoor-client-id |
| 应用名称(Name) | your-casdoor-app-name | CONSOLE_CASDOOR_APP=your-casdoor-app-name |
| 组织名称(Organization) | your-casdoor-org-name | CONSOLE_CASDOOR_ORG=your-casdoor-org-name |
# 进入 astronAgent 目录
cd docker/astronAgent
# 编辑环境变量配置
vim .env
在 .env 文件中添加或更新以下配置项:
# Casdoor配置
CONSOLE_CASDOOR_URL=http://localhost:8000
CONSOLE_CASDOOR_ID=your-casdoor-client-id
CONSOLE_CASDOOR_APP=your-casdoor-app-name
CONSOLE_CASDOOR_ORG=your-casdoor-org-name
docker compose restart console-frontend console-hub
启动完成后,您可以通过以下地址访问各项服务:
如遇到问题,请:
注意:首次部署项目建议在测试环境中验证所有功能后再部署到生产环境。