| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- # New-API Docker Compose Configuration
- #
- # Quick Start:
- # 1. docker-compose up -d
- # 2. Access at http://localhost:3000
- #
- # Using MySQL instead of PostgreSQL:
- # 1. Comment out the postgres service and SQL_DSN line 15
- # 2. Uncomment the mysql service and SQL_DSN line 16
- # 3. Uncomment mysql in depends_on (line 28)
- # 4. Uncomment mysql_data in volumes section (line 64)
- #
- # ⚠️ IMPORTANT: Change all default passwords before deploying to production!
- version: '3.4' # For compatibility with older Docker versions
- services:
- new-api:
- image: calciumion/new-api:latest
- container_name: new-api
- restart: always
- command: --log-dir /app/logs
- ports:
- - "3000:3000"
- volumes:
- - ./data:/data
- - ./logs:/app/logs
- environment:
- - SQL_DSN=postgresql://root:123456@postgres:5432/new-api # ⚠️ IMPORTANT: Change the password in production!
- # - SQL_DSN=root:123456@tcp(mysql:3306)/new-api # Point to the mysql service, uncomment if using MySQL
- - REDIS_CONN_STRING=redis://redis
- - TZ=Asia/Shanghai
- - ERROR_LOG_ENABLED=true # 是否启用错误日志记录 (Whether to enable error log recording)
- - BATCH_UPDATE_ENABLED=true # 是否启用批量更新 (Whether to enable batch update)
- # - STREAMING_TIMEOUT=300 # 流模式无响应超时时间,单位秒,默认120秒,如果出现空补全可以尝试改为更大值 (Streaming timeout in seconds, default is 120s. Increase if experiencing empty completions)
- # - SESSION_SECRET=random_string # 多机部署时设置,必须修改这个随机字符串!! (multi-node deployment, set this to a random string!!!!!!!)
- # - SYNC_FREQUENCY=60 # Uncomment if regular database syncing is needed
- # - GOOGLE_ANALYTICS_ID=G-XXXXXXXXXX # Google Analytics 的测量 ID (Google Analytics Measurement ID)
- # - UMAMI_WEBSITE_ID=xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx # Umami 网站 ID (Umami Website ID)
- # - UMAMI_SCRIPT_URL=https://analytics.umami.is/script.js # Umami 脚本 URL,默认为官方地址 (Umami Script URL, defaults to official URL)
- depends_on:
- - redis
- - postgres
- # - mysql # Uncomment if using MySQL
- healthcheck:
- test: ["CMD-SHELL", "wget -q -O - http://localhost:3000/api/status | grep -o '\"success\":\\s*true' || exit 1"]
- interval: 30s
- timeout: 10s
- retries: 3
- redis:
- image: redis:latest
- container_name: redis
- restart: always
- postgres:
- image: postgres:15
- container_name: postgres
- restart: always
- environment:
- POSTGRES_USER: root
- POSTGRES_PASSWORD: 123456 # ⚠️ IMPORTANT: Change this password in production!
- POSTGRES_DB: new-api
- volumes:
- - pg_data:/var/lib/postgresql/data
- # ports:
- # - "5432:5432" # Uncomment if you need to access PostgreSQL from outside Docker
- # mysql:
- # image: mysql:8.2
- # container_name: mysql
- # restart: always
- # environment:
- # MYSQL_ROOT_PASSWORD: 123456 # ⚠️ IMPORTANT: Change this password in production!
- # MYSQL_DATABASE: new-api
- # volumes:
- # - mysql_data:/var/lib/mysql
- # ports:
- # - "3306:3306" # Uncomment if you need to access MySQL from outside Docker
- volumes:
- pg_data:
- # mysql_data:
|