version: '3.4' services: one-api: image: "${REGISTRY:-docker.io}/justsong/one-api:latest" container_name: one-api restart: always command: --log-dir /app/logs ports: - "3000:3000" volumes: - ./data/oneapi:/data - ./logs:/app/logs environment: - SQL_DSN=oneapi:123456@tcp(db:3306)/one-api # 修改此行,或注释掉以使用 SQLite 作为数据库 - REDIS_CONN_STRING=redis://redis - SESSION_SECRET=random_string # 修改为随机字符串 - TZ=Asia/Shanghai # - NODE_TYPE=slave # 多机部署时从节点取消注释该行 # - SYNC_FREQUENCY=60 # 需要定期从数据库加载数据时取消注释该行 # - FRONTEND_BASE_URL=https://openai.justsong.cn # 多机部署时从节点取消注释该行 depends_on: - redis - db healthcheck: test: [ "CMD-SHELL", "wget -q -O - http://localhost:3000/api/status | grep -o '\"success\":\\s*true' | awk -F: '{print $2}'" ] interval: 30s timeout: 10s retries: 3 redis: image: "${REGISTRY:-docker.io}/redis:latest" container_name: redis restart: always db: image: "${REGISTRY:-docker.io}/mysql:8.2.0" restart: always container_name: mysql volumes: - ./data/mysql:/var/lib/mysql # 挂载目录,持久化存储 ports: - '3306:3306' environment: TZ: Asia/Shanghai # 设置时区 MYSQL_ROOT_PASSWORD: 'OneAPI@justsong' # 设置 root 用户的密码 MYSQL_USER: oneapi # 创建专用用户 MYSQL_PASSWORD: '123456' # 设置专用用户密码 MYSQL_DATABASE: one-api # 自动创建数据库