-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
151 lines (143 loc) · 3.92 KB
/
docker-compose.yml
File metadata and controls
151 lines (143 loc) · 3.92 KB
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
services:
# MySQL 数据库
mysql:
image: mysql:8.0
container_name: smartats-mysql
environment:
MYSQL_ROOT_PASSWORD: root123
MYSQL_DATABASE: smartats
MYSQL_USER: smartats
MYSQL_PASSWORD: smartats123
TZ: Asia/Shanghai
ports:
- "3307:3306" # 映射到宿主机 3307 端口,避免与本地 MySQL 冲突
volumes:
- ./data/mysql:/var/lib/mysql
- ./docker/mysql/init:/docker-entrypoint-initdb.d
command:
- --character-set-server=utf8mb4
- --collation-server=utf8mb4_unicode_ci
- --default-authentication-plugin=mysql_native_password
networks:
- smartats-network
healthcheck:
test: ["CMD", "mysqladmin", "ping", "-h", "localhost", "-uroot", "-proot123"]
interval: 10s
timeout: 5s
retries: 5
# Redis 缓存
redis:
image: redis:7.0-alpine
container_name: smartats-redis
ports:
- "6379:6379"
volumes:
- ./data/redis:/data
command: redis-server --appendonly yes --requirepass redis123
networks:
- smartats-network
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 10s
timeout: 3s
retries: 5
# RabbitMQ 消息队列
rabbitmq:
image: rabbitmq:3.12-management
container_name: smartats-rabbitmq
environment:
RABBITMQ_DEFAULT_USER: admin
RABBITMQ_DEFAULT_PASS: admin123
RABBITMQ_DEFAULT_VHOST: smartats
ports:
- "5672:5672" # AMQP 协议端口
- "15672:15672" # 管理界面端口
volumes:
- ./data/rabbitmq:/var/lib/rabbitmq
networks:
- smartats-network
healthcheck:
test: ["CMD", "rabbitmq-diagnostics", "ping"]
interval: 10s
timeout: 5s
retries: 5
# MinIO 对象存储(用于简历文件存储)
minio:
image: minio/minio:latest
container_name: smartats-minio
command: server /data --console-address ":9001"
environment:
MINIO_ROOT_USER: admin
MINIO_ROOT_PASSWORD: admin123456
ports:
- "9000:9000" # API 端口
- "9001:9001" # 控制台端口
volumes:
- ./data/minio:/data
networks:
- smartats-network
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"]
interval: 10s
timeout: 5s
retries: 5
# ==================== Milvus 向量数据库 ====================
# etcd — Milvus 元数据存储
etcd:
image: quay.io/coreos/etcd:v3.5.16
container_name: smartats-etcd
environment:
ETCD_AUTO_COMPACTION_MODE: revision
ETCD_AUTO_COMPACTION_RETENTION: "1000"
ETCD_QUOTA_BACKEND_BYTES: "4294967296" # 4GB
ETCD_SNAPSHOT_COUNT: "50000"
volumes:
- ./data/etcd:/etcd
command: etcd -advertise-client-urls=http://127.0.0.1:2379 -listen-client-urls http://0.0.0.0:2379 --data-dir /etcd
networks:
- smartats-network
healthcheck:
test: ["CMD", "etcdctl", "endpoint", "health"]
interval: 30s
timeout: 20s
retries: 3
# Milvus Standalone — 向量数据库
milvus:
image: milvusdb/milvus:v2.4.17
container_name: smartats-milvus
command: ["milvus", "run", "standalone"]
security_opt:
- seccomp:unconfined
environment:
ETCD_ENDPOINTS: etcd:2379
MINIO_ADDRESS: minio:9000
MINIO_ACCESS_KEY_ID: admin
MINIO_SECRET_ACCESS_KEY: admin123456
ports:
- "19530:19530" # gRPC 端口
- "9091:9091" # 健康检查端口
volumes:
- ./data/milvus:/var/lib/milvus
depends_on:
etcd:
condition: service_healthy
minio:
condition: service_healthy
networks:
- smartats-network
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:9091/healthz"]
interval: 30s
start_period: 90s
timeout: 20s
retries: 3
networks:
smartats-network:
driver: bridge
volumes:
mysql-data:
redis-data:
rabbitmq-data:
minio-data:
etcd-data:
milvus-data: