forked from MartialBE/one-hub
-
Notifications
You must be signed in to change notification settings - Fork 0
/
docker-compose.yml
54 lines (51 loc) · 1.85 KB
/
docker-compose.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
version: "3.4"
services:
portal:
image: martialbe/one-api:latest
container_name: one-hub-portal
restart: always
ports:
- "${ONE_HUB_PORT}:3000"
volumes:
- ./data/portal:/data
- ./logs:/app/logs
environment:
- SQL_DSN=${MYSQL_USER}:${MYSQL_PASSWORD}@tcp(db:3306)/${MYSQL_DATABASE} # 修改此行,或注释掉以使用 SQLite 作为数据库
- REDIS_CONN_STRING=redis://redis
- SESSION_SECRET=random_string # 修改为随机字符串
- USER_TOKEN_SECRET=random_string # 修改为随机字符串,32位以上
- TZ=Asia/Shanghai
# - HASHIDS_SALT=random_string # 可空,建议设置,字符串元素不能重复
# - 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:${ONE_HUB_PORT}/api/status | grep -o '\"success\":\\s*true' | awk -F: '{print $2}'",
]
interval: 30s
timeout: 10s
retries: 3
redis:
image: redis:latest
container_name: one-hub-redis
restart: always
db:
image: mysql:${MYSQL_VERSION}
restart: always
container_name: one-hub-mysql
volumes:
- ./data/mysql:/var/lib/mysql # 挂载目录,持久化存储
ports:
- "${MYSQL_HOST_PORT}:3306"
environment:
TZ: Asia/Shanghai # 设置时区
MYSQL_ROOT_PASSWORD: "${MYSQL_ROOT_PASSWORD}" # 设置 root 用户的密码
MYSQL_USER: "${MYSQL_USER}" # 创建专用用户
MYSQL_PASSWORD: "${MYSQL_PASSWORD}" # 设置专用用户密码
MYSQL_DATABASE: "${MYSQL_DATABASE}" # 自动创建数据库