diff --git a/deploy/docker/docker-compose-oceanbase/docker-compose.yml b/deploy/docker/docker-compose-oceanbase/docker-compose.yml new file mode 100644 index 000000000..499cad3c1 --- /dev/null +++ b/deploy/docker/docker-compose-oceanbase/docker-compose.yml @@ -0,0 +1,202 @@ +# 数据库的默认账号和密码仅首次运行时设置有效 +# 如果修改了账号密码,记得改数据库和项目连接参数,别只改一处~ +# 该配置文件只是给快速启动,测试使用。正式使用,记得务必修改账号密码,以及调整合适的知识库参数,共享内存等。 +# 如何无法访问 dockerhub 和 git,可以用阿里云(阿里云没有arm包) + +version: '3.3' +services: + # vector db + ob: + image: oceanbase/oceanbase-ce # docker hub + # image: quay.io/oceanbase/oceanbase-ce:4.3.5.1-101000042025031818 # 镜像 + container_name: ob + restart: always + # ports: # 生产环境建议不要暴露 + # - 2881:2881 + networks: + - fastgpt + environment: + # 这里的配置只有首次运行生效。修改后,重启镜像是不会生效的。需要把持久化数据删除再重启,才有效果 + - OB_SYS_PASSWORD=obsyspassword + # 不同于传统数据库,OceanBase 数据库的账号包含更多字段,包括用户名、租户名和集群名。经典格式为“用户名@租户名#集群名” + # 比如用mysql客户端连接时,根据本文件的默认配置,应该指定 “-uroot@tenantname” + - OB_TENANT_NAME=tenantname + - OB_TENANT_PASSWORD=tenantpassword + # MODE分为MINI和NORMAL, 后者会最大程度使用主机资源 + - MODE=NORMAL + - OB_SERVER_IP=127.0.0.1 + # 更多环境变量配置见oceanbase官方文档: https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013494 + volumes: + - ./ob/data:/root/ob + - ./ob/config:/root/.obd/cluster + - ./init.sql:/root/boot/init.d/init.sql + healthcheck: + # obclient -h127.0.0.1 -P2881 -uroot@tenantname -ptenantpassword -e "SELECT 1;" + test: ["CMD-SHELL", "obclient -h$OB_SERVER_IP -P2881 -uroot@$OB_TENANT_NAME -p$OB_TENANT_PASSWORD -e \"SELECT 1;\""] + interval: 30s + timeout: 10s + retries: 1000 + start_period: 10s + mongo: + image: mongo:5.0.18 # dockerhub + # image: registry.cn-hangzhou.aliyuncs.com/fastgpt/mongo:5.0.18 # 阿里云 + # image: mongo:4.4.29 # cpu不支持AVX时候使用 + container_name: mongo + restart: always + # ports: + # - 27017:27017 + networks: + - fastgpt + command: mongod --keyFile /data/mongodb.key --replSet rs0 + environment: + - MONGO_INITDB_ROOT_USERNAME=myusername + - MONGO_INITDB_ROOT_PASSWORD=mypassword + volumes: + - ./mongo/data:/data/db + entrypoint: + - bash + - -c + - | + openssl rand -base64 128 > /data/mongodb.key + chmod 400 /data/mongodb.key + chown 999:999 /data/mongodb.key + echo 'const isInited = rs.status().ok === 1 + if(!isInited){ + rs.initiate({ + _id: "rs0", + members: [ + { _id: 0, host: "mongo:27017" } + ] + }) + }' > /data/initReplicaSet.js + # 启动MongoDB服务 + exec docker-entrypoint.sh "$$@" & + + # 等待MongoDB服务启动 + until mongo -u myusername -p mypassword --authenticationDatabase admin --eval "print('waited for connection')"; do + echo "Waiting for MongoDB to start..." + sleep 2 + done + + # 执行初始化副本集的脚本 + mongo -u myusername -p mypassword --authenticationDatabase admin /data/initReplicaSet.js + + # 等待docker-entrypoint.sh脚本执行的MongoDB服务进程 + wait $$! + + # fastgpt + sandbox: + container_name: sandbox + image: ghcr.io/labring/fastgpt-sandbox:v4.9.3 # git + # image: registry.cn-hangzhou.aliyuncs.com/fastgpt/fastgpt-sandbox:v4.9.3 # 阿里云 + networks: + - fastgpt + restart: always + fastgpt: + container_name: fastgpt + image: ghcr.io/labring/fastgpt:v4.9.3 # git + # image: registry.cn-hangzhou.aliyuncs.com/fastgpt/fastgpt:v4.9.3 # 阿里云 + ports: + - 3000:3000 + networks: + - fastgpt + depends_on: + mongo: + condition: service_started + ob: + condition: service_healthy + sandbox: + condition: service_started + restart: always + environment: + # 前端外部可访问的地址,用于自动补全文件资源路径。例如 https:fastgpt.cn,不能填 localhost。这个值可以不填,不填则发给模型的图片会是一个相对路径,而不是全路径,模型可能伪造Host。 + - FE_DOMAIN= + # root 密码,用户名为: root。如果需要修改 root 密码,直接修改这个环境变量,并重启即可。 + - DEFAULT_ROOT_PSW=1234 + # # AI Proxy 的地址,如果配了该地址,优先使用 + # - AIPROXY_API_ENDPOINT=http://aiproxy:3000 + # # AI Proxy 的 Admin Token,与 AI Proxy 中的环境变量 ADMIN_KEY + # - AIPROXY_API_TOKEN=aiproxy + # 模型中转地址(如果用了 AI Proxy,下面 2 个就不需要了,旧版 OneAPI 用户,使用下面的变量) + - # openai 基本地址,可用作中转。 + - OPENAI_BASE_URL=https://dashscope.aliyuncs.com/compatible-mode/v1 + - # OpenAI API Key + - CHAT_API_KEY=sk-8990fa15a34b464a805237cfe9561f11 + # 数据库最大连接数 + - DB_MAX_LINK=30 + # 登录凭证密钥 + - TOKEN_KEY=any + # root的密钥,常用于升级时候的初始化请求 + - ROOT_KEY=root_key + # 文件阅读加密 + - FILE_TOKEN_KEY=filetoken + # MongoDB 连接参数. 用户名myusername,密码mypassword。 + - MONGODB_URI=mongodb://myusername:mypassword@mongo:27017/fastgpt?authSource=admin + # OceanBase 向量库连接参数 + - OCEANBASE_URL=mysql://root%40tenantname:tenantpassword@ob:2881/test + # sandbox 地址 + - SANDBOX_URL=http://sandbox:3000 + # 日志等级: debug, info, warn, error + - LOG_LEVEL=info + - STORE_LOG_LEVEL=warn + # 工作流最大运行次数 + - WORKFLOW_MAX_RUN_TIMES=1000 + # 批量执行节点,最大输入长度 + - WORKFLOW_MAX_LOOP_TIMES=100 + # 自定义跨域,不配置时,默认都允许跨域(多个域名通过逗号分割) + - ALLOWED_ORIGINS= + # 是否开启IP限制,默认不开启 + - USE_IP_LIMIT=false + volumes: + - ./config.json:/app/data/config.json + + # AI Proxy + aiproxy: + image: ghcr.io/labring/aiproxy:v0.1.5 + # image: registry.cn-hangzhou.aliyuncs.com/labring/aiproxy:v0.1.3 # 阿里云 + container_name: aiproxy + restart: unless-stopped + depends_on: + aiproxy_pg: + condition: service_healthy + networks: + - fastgpt + environment: + # 对应 fastgpt 里的AIPROXY_API_TOKEN + - ADMIN_KEY=aiproxy + # 错误日志详情保存时间(小时) + - LOG_DETAIL_STORAGE_HOURS=1 + # 数据库连接地址 + - SQL_DSN=postgres://postgres:aiproxy@aiproxy_pg:5432/aiproxy + # 最大重试次数 + - RETRY_TIMES=3 + # 不需要计费 + - BILLING_ENABLED=false + # 不需要严格检测模型 + - DISABLE_MODEL_CONFIG=true + healthcheck: + test: ['CMD', 'curl', '-f', 'http://localhost:3000/api/status'] + interval: 5s + timeout: 5s + retries: 10 + aiproxy_pg: + image: pgvector/pgvector:0.8.0-pg15 # docker hub + # image: registry.cn-hangzhou.aliyuncs.com/fastgpt/pgvector:v0.8.0-pg15 # 阿里云 + restart: unless-stopped + container_name: aiproxy_pg + volumes: + - ./aiproxy_pg:/var/lib/postgresql/data + networks: + - fastgpt + environment: + TZ: Asia/Shanghai + POSTGRES_USER: postgres + POSTGRES_DB: aiproxy + POSTGRES_PASSWORD: aiproxy + healthcheck: + test: ['CMD', 'pg_isready', '-U', 'postgres', '-d', 'aiproxy'] + interval: 5s + timeout: 5s + retries: 10 +networks: + fastgpt: diff --git a/deploy/docker/docker-compose-oceanbase/init.sql b/deploy/docker/docker-compose-oceanbase/init.sql new file mode 100644 index 000000000..9bea8486d --- /dev/null +++ b/deploy/docker/docker-compose-oceanbase/init.sql @@ -0,0 +1,2 @@ +ALTER SYSTEM SET ob_vector_memory_limit_percentage = 30; + diff --git a/docSite/content/zh-cn/docs/development/docker.md b/docSite/content/zh-cn/docs/development/docker.md index b447b0b82..e38ccb8c5 100644 --- a/docSite/content/zh-cn/docs/development/docker.md +++ b/docSite/content/zh-cn/docs/development/docker.md @@ -135,6 +135,9 @@ curl -O https://raw.githubusercontent.com/labring/FastGPT/main/projects/app/data # pgvector 版本(测试推荐,简单快捷) curl -o docker-compose.yml https://raw.githubusercontent.com/labring/FastGPT/main/deploy/docker/docker-compose-pgvector.yml +# oceanbase 版本(需要将init.sql和docker-compose.yml放在同一个文件夹,方便挂载) +# curl -o docker-compose.yml https://raw.githubusercontent.com/labring/FastGPT/main/deploy/docker/docker-compose-oceanbase/docker-compose.yml +# curl -o init.sql https://raw.githubusercontent.com/labring/FastGPT/main/deploy/docker/docker-compose-oceanbase/init.sql # milvus 版本 # curl -o docker-compose.yml https://raw.githubusercontent.com/labring/FastGPT/main/deploy/docker/docker-compose-milvus.yml # zilliz 版本 @@ -151,6 +154,13 @@ curl -o docker-compose.yml https://raw.githubusercontent.com/labring/FastGPT/mai 无需操作 +{{< /markdownify >}} +{{< /tab >}} +{{< tab tabName="Oceanbase版本" >}} +{{< markdownify >}} + +无需操作 + {{< /markdownify >}} {{< /tab >}} {{< tab tabName="Milvus版本" >}}