338 lines
9.2 KiB
YAML
Executable File
338 lines
9.2 KiB
YAML
Executable File
x-env-file: &env_file
|
|
- .env
|
|
|
|
services:
|
|
mysql:
|
|
image: mysql:8.4.5
|
|
container_name: coze-mysql
|
|
restart: always
|
|
environment:
|
|
MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD:-root}
|
|
MYSQL_DATABASE: ${MYSQL_DATABASE:-opencoze}
|
|
MYSQL_USER: ${MYSQL_USER:-coze}
|
|
MYSQL_PASSWORD: ${MYSQL_PASSWORD:-coze123}
|
|
env_file: *env_file
|
|
ports:
|
|
- '3306'
|
|
volumes:
|
|
- ./data/mysql:/var/lib/mysql
|
|
- ./volumes/mysql/schema.sql:/docker-entrypoint-initdb.d/init.sql
|
|
command:
|
|
- --character-set-server=utf8mb4
|
|
- --collation-server=utf8mb4_unicode_ci
|
|
healthcheck:
|
|
test:
|
|
[
|
|
'CMD',
|
|
'mysqladmin',
|
|
'ping',
|
|
'-h',
|
|
'localhost',
|
|
'-u$${MYSQL_USER}',
|
|
'-p$${MYSQL_PASSWORD}',
|
|
]
|
|
interval: 10s
|
|
timeout: 5s
|
|
retries: 5
|
|
start_period: 30s
|
|
networks:
|
|
- coze-network
|
|
|
|
redis:
|
|
image: bitnami/redis:8.0
|
|
container_name: coze-redis
|
|
restart: always
|
|
user: root
|
|
privileged: true
|
|
env_file: *env_file
|
|
environment:
|
|
- REDIS_AOF_ENABLED=${REDIS_AOF_ENABLED:-no}
|
|
- REDIS_PORT_NUMBER=${REDIS_PORT_NUMBER:-6379}
|
|
- REDIS_IO_THREADS=${REDIS_IO_THREADS:-4}
|
|
- ALLOW_EMPTY_PASSWORD=${ALLOW_EMPTY_PASSWORD:-yes}
|
|
ports:
|
|
- '6379'
|
|
volumes:
|
|
- ./data/bitnami/redis:/bitnami/redis/data:rw,Z
|
|
command: >
|
|
bash -c "
|
|
/opt/bitnami/scripts/redis/setup.sh
|
|
# Set proper permissions for data directories
|
|
chown -R redis:redis /bitnami/redis/data
|
|
chmod g+s /bitnami/redis/data
|
|
|
|
exec /opt/bitnami/scripts/redis/entrypoint.sh /opt/bitnami/scripts/redis/run.sh
|
|
"
|
|
healthcheck:
|
|
test: ['CMD', 'redis-cli', 'ping']
|
|
interval: 5s
|
|
timeout: 10s
|
|
retries: 10
|
|
start_period: 10s
|
|
networks:
|
|
- coze-network
|
|
elasticsearch:
|
|
image: bitnami/elasticsearch:8.18.0
|
|
container_name: coze-elasticsearch
|
|
restart: always
|
|
user: root
|
|
privileged: true
|
|
env_file: *env_file
|
|
environment:
|
|
- TEST=1
|
|
# Add Java certificate trust configuration
|
|
# - ES_JAVA_OPTS=-Djdk.tls.client.protocols=TLSv1.2 -Dhttps.protocols=TLSv1.2 -Djavax.net.ssl.trustAll=true -Xms4096m -Xmx4096m
|
|
ports:
|
|
- '9200'
|
|
volumes:
|
|
- ./data/bitnami/elasticsearch:/bitnami/elasticsearch/data
|
|
- ./volumes/elasticsearch/elasticsearch.yml:/opt/bitnami/elasticsearch/config/my_elasticsearch.yml
|
|
- ./volumes/elasticsearch/analysis-smartcn.zip:/opt/bitnami/elasticsearch/analysis-smartcn.zip:rw,Z
|
|
healthcheck:
|
|
test:
|
|
[
|
|
'CMD-SHELL',
|
|
'curl -f http://localhost:9200 && [ -f /tmp/es_plugins_ready ]',
|
|
]
|
|
interval: 5s
|
|
timeout: 10s
|
|
retries: 10
|
|
start_period: 10s
|
|
networks:
|
|
- coze-network
|
|
# Install smartcn analyzer plugin
|
|
command: >
|
|
bash -c "
|
|
/opt/bitnami/scripts/elasticsearch/setup.sh
|
|
# Set proper permissions for data directories
|
|
chown -R elasticsearch:elasticsearch /bitnami/elasticsearch/data
|
|
chmod g+s /bitnami/elasticsearch/data
|
|
|
|
# Create plugin directory
|
|
mkdir -p /bitnami/elasticsearch/plugins;
|
|
|
|
# Unzip plugin to plugin directory and set correct permissions
|
|
echo 'Installing smartcn plugin...';
|
|
if [ ! -d /opt/bitnami/elasticsearch/plugins/analysis-smartcn ]; then
|
|
|
|
# Download plugin package locally
|
|
echo 'Copying smartcn plugin...';
|
|
cp /opt/bitnami/elasticsearch/analysis-smartcn.zip /tmp/analysis-smartcn.zip
|
|
|
|
elasticsearch-plugin install file:///tmp/analysis-smartcn.zip
|
|
if [[ "$$?" != "0" ]]; then
|
|
echo 'Plugin installation failed, exiting operation';
|
|
rm -rf /opt/bitnami/elasticsearch/plugins/analysis-smartcn
|
|
exit 1;
|
|
fi;
|
|
rm -f /tmp/analysis-smartcn.zip;
|
|
fi;
|
|
|
|
# Create marker file indicating plugin installation success
|
|
touch /tmp/es_plugins_ready;
|
|
echo 'Plugin installation successful, marker file created';
|
|
|
|
# Start Elasticsearch
|
|
exec /opt/bitnami/scripts/elasticsearch/entrypoint.sh /opt/bitnami/scripts/elasticsearch/run.sh
|
|
|
|
echo -e "⏳ Adjusting Elasticsearch disk watermark settings..."
|
|
"
|
|
|
|
minio:
|
|
image: minio/minio:RELEASE.2025-06-13T11-33-47Z-cpuv1
|
|
container_name: coze-minio
|
|
user: root
|
|
privileged: true
|
|
restart: always
|
|
env_file: *env_file
|
|
ports:
|
|
- '9000'
|
|
- '9001'
|
|
volumes:
|
|
- ./data/minio:/data
|
|
- ./volumes/minio/default_icon/:/default_icon
|
|
- ./volumes/minio/official_plugin_icon/:/official_plugin_icon
|
|
- ./volumes/minio/initialize.sh:/initialize.sh
|
|
environment:
|
|
MINIO_ROOT_USER: ${MINIO_ROOT_USER:-minioadmin}
|
|
MINIO_ROOT_PASSWORD: ${MINIO_ROOT_PASSWORD:-minioadmin123}
|
|
MINIO_DEFAULT_BUCKETS: ${MINIO_BUCKET:-opencoze},${MINIO_DEFAULT_BUCKETS:-milvus}
|
|
entrypoint: ['/bin/sh', '/initialize.sh']
|
|
healthcheck:
|
|
test:
|
|
[
|
|
'CMD-SHELL',
|
|
'/usr/bin/mc alias set health_check http://localhost:9000 ${MINIO_ROOT_USER} ${MINIO_ROOT_PASSWORD} && /usr/bin/mc ready health_check',
|
|
]
|
|
interval: 30s
|
|
timeout: 10s
|
|
retries: 3
|
|
start_period: 30s
|
|
networks:
|
|
- coze-network
|
|
|
|
etcd:
|
|
image: bitnami/etcd:3.5
|
|
container_name: coze-etcd
|
|
user: root
|
|
restart: always
|
|
privileged: true
|
|
env_file: *env_file
|
|
environment:
|
|
- ETCD_AUTO_COMPACTION_MODE=revision
|
|
- ETCD_AUTO_COMPACTION_RETENTION=1000
|
|
- ETCD_QUOTA_BACKEND_BYTES=4294967296
|
|
- ALLOW_NONE_AUTHENTICATION=yes
|
|
ports:
|
|
- 2379:2379
|
|
- 2380:2380
|
|
volumes:
|
|
- ./data/bitnami/etcd:/bitnami/etcd:rw,Z
|
|
- ./volumes/etcd/etcd.conf.yml:/opt/bitnami/etcd/conf/etcd.conf.yml:ro,Z
|
|
command: >
|
|
bash -c "
|
|
/opt/bitnami/scripts/etcd/setup.sh
|
|
# Set proper permissions for data and config directories
|
|
chown -R etcd:etcd /bitnami/etcd
|
|
chmod g+s /bitnami/etcd
|
|
|
|
exec /opt/bitnami/scripts/etcd/entrypoint.sh /opt/bitnami/scripts/etcd/run.sh
|
|
"
|
|
healthcheck:
|
|
test: ['CMD', 'etcdctl', 'endpoint', 'health']
|
|
interval: 5s
|
|
timeout: 10s
|
|
retries: 10
|
|
start_period: 10s
|
|
networks:
|
|
- coze-network
|
|
|
|
milvus:
|
|
container_name: coze-milvus
|
|
image: milvusdb/milvus:v2.5.10
|
|
user: root
|
|
privileged: true
|
|
restart: always
|
|
env_file: *env_file
|
|
command: >
|
|
bash -c "
|
|
# Set proper permissions for data directories
|
|
chown -R root:root /var/lib/milvus
|
|
chmod g+s /var/lib/milvus
|
|
|
|
exec milvus run standalone
|
|
"
|
|
security_opt:
|
|
- seccomp:unconfined
|
|
environment:
|
|
ETCD_ENDPOINTS: coze-etcd:2379
|
|
MINIO_ADDRESS: coze-minio:9000
|
|
MINIO_BUCKET_NAME: ${MINIO_BUCKET:-milvus}
|
|
MINIO_ACCESS_KEY_ID: ${MINIO_ROOT_USER:-minioadmin}
|
|
MINIO_SECRET_ACCESS_KEY: ${MINIO_ROOT_PASSWORD:-minioadmin123}
|
|
MINIO_USE_SSL: false
|
|
LOG_LEVEL: debug
|
|
volumes:
|
|
- ./data/milvus:/var/lib/milvus:rw,Z
|
|
healthcheck:
|
|
test: ['CMD', 'curl', '-f', 'http://localhost:9091/healthz']
|
|
interval: 5s
|
|
timeout: 10s
|
|
retries: 10
|
|
start_period: 10s
|
|
ports:
|
|
- '19530'
|
|
- '9091'
|
|
depends_on:
|
|
etcd:
|
|
condition: service_healthy
|
|
minio:
|
|
condition: service_healthy
|
|
networks:
|
|
- coze-network
|
|
nsqlookupd:
|
|
image: nsqio/nsq:v1.2.1
|
|
container_name: coze-nsqlookupd
|
|
command: /nsqlookupd
|
|
restart: always
|
|
ports:
|
|
- '4160'
|
|
- '4161'
|
|
networks:
|
|
- coze-network
|
|
healthcheck:
|
|
test: ['CMD-SHELL', 'nsqlookupd --version']
|
|
interval: 5s
|
|
timeout: 10s
|
|
retries: 10
|
|
start_period: 10s
|
|
|
|
nsqd:
|
|
image: nsqio/nsq:v1.2.1
|
|
container_name: coze-nsqd
|
|
command: /nsqd --lookupd-tcp-address=coze-nsqlookupd:4160 --broadcast-address=coze-nsqd
|
|
restart: always
|
|
ports:
|
|
- '4150'
|
|
- '4151'
|
|
depends_on:
|
|
nsqlookupd:
|
|
condition: service_healthy
|
|
networks:
|
|
- coze-network
|
|
healthcheck:
|
|
test: ['CMD-SHELL', '/nsqd --version']
|
|
interval: 5s
|
|
timeout: 10s
|
|
retries: 10
|
|
start_period: 10s
|
|
|
|
nsqadmin:
|
|
image: nsqio/nsq:v1.2.1
|
|
container_name: coze-nsqadmin
|
|
command: /nsqadmin --lookupd-http-address=coze-nsqlookupd:4161
|
|
restart: always
|
|
ports:
|
|
- '4171'
|
|
depends_on:
|
|
nsqlookupd:
|
|
condition: service_healthy
|
|
networks:
|
|
- coze-network
|
|
|
|
coze-server:
|
|
# build:
|
|
# context: ../
|
|
# dockerfile: backend/Dockerfile
|
|
image: opencoze/opencoze:latest
|
|
restart: always
|
|
container_name: coze-server
|
|
env_file: *env_file
|
|
environment:
|
|
LISTEN_ADDR: 0.0.0.0:8888
|
|
networks:
|
|
- coze-network
|
|
ports:
|
|
- '8888:8888'
|
|
- '8889:8889'
|
|
volumes:
|
|
- .env:/app/.env
|
|
- ../backend/conf:/app/resources/conf
|
|
# - ../backend/static:/app/resources/static
|
|
depends_on:
|
|
mysql:
|
|
condition: service_healthy
|
|
redis:
|
|
condition: service_healthy
|
|
elasticsearch:
|
|
condition: service_healthy
|
|
minio:
|
|
condition: service_healthy
|
|
milvus:
|
|
condition: service_healthy
|
|
command: ['/app/bootstrap.sh']
|
|
|
|
networks:
|
|
coze-network:
|
|
driver: bridge
|