63 行
3.0 KiB
YAML
63 行
3.0 KiB
YAML
# =============================================================================
|
||
# XuqmGroup 私有化部署 — 基础设施服务(MySQL / Redis)
|
||
#
|
||
# 使用场景:MYSQL_MODE=managed 或 REDIS_MODE=managed 时,
|
||
# 由 Docker Compose 启动容器化数据库,无需客户自备。
|
||
#
|
||
# 生产环境建议使用客户自备的 external 模式,由 DBA 管理数据库。
|
||
# 开发/体验环境可使用 managed 模式快速启动。
|
||
#
|
||
# 数据目录:
|
||
# MySQL 数据 → ./data/mysql (重启后保留)
|
||
# Redis 数据 → ./data/redis (AOF 持久化,重启后保留)
|
||
# =============================================================================
|
||
|
||
services:
|
||
|
||
# ---------------------------------------------------------------------------
|
||
# MySQL 8.4(托管模式,profile: infra-mysql)
|
||
# 仅在 MYSQL_MODE=managed 时启用
|
||
# 首次启动自动创建数据库和业务账号
|
||
# ---------------------------------------------------------------------------
|
||
mysql:
|
||
image: mysql:8.4
|
||
profiles: ["infra-mysql"]
|
||
environment:
|
||
MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD} # root 密码(见 config/secrets.env)
|
||
MYSQL_DATABASE: ${MYSQL_DATABASE} # 自动创建的数据库名
|
||
MYSQL_USER: ${MYSQL_USERNAME} # 业务账号(自动创建)
|
||
MYSQL_PASSWORD: ${MYSQL_PASSWORD} # 业务账号密码
|
||
TZ: Asia/Shanghai # 时区,与 Spring Boot 保持一致
|
||
command:
|
||
- --character-set-server=utf8mb4 # 服务器默认字符集,支持中文和 emoji
|
||
- --collation-server=utf8mb4_unicode_ci # 排序规则
|
||
- --default-time-zone=+08:00 # 数据库时区
|
||
ports:
|
||
# 暴露到宿主机,方便外部工具(如 Navicat)连接
|
||
# 生产环境可注释此行,仅允许容器内部访问
|
||
- "${MYSQL_PORT:-3306}:3306"
|
||
volumes:
|
||
- ./data/mysql:/var/lib/mysql # 数据持久化,重启后保留
|
||
restart: unless-stopped
|
||
|
||
# ---------------------------------------------------------------------------
|
||
# Redis 7.4(托管模式,profile: infra-redis)
|
||
# 仅在 REDIS_MODE=managed 时启用
|
||
# 启用 AOF 持久化,重启后数据不丢失
|
||
# ---------------------------------------------------------------------------
|
||
redis:
|
||
image: redis:7.4-alpine
|
||
profiles: ["infra-redis"]
|
||
command:
|
||
- redis-server
|
||
- --appendonly yes # 开启 AOF 持久化
|
||
- --requirepass ${REDIS_PASSWORD} # 密码(见 config/secrets.env)
|
||
ports:
|
||
# 暴露到宿主机,方便调试(仅本地可达,127.0.0.1 绑定)
|
||
# REDIS_HOST_PORT 默认 16379,避免与宿主机原有 Redis / WSL2 端口代理冲突
|
||
# 内部服务始终通过容器名 redis:6379 连接,此端口仅供外部工具调试用
|
||
- "127.0.0.1:${REDIS_HOST_PORT:-16379}:6379"
|
||
volumes:
|
||
- ./data/redis:/data # AOF 文件持久化目录
|
||
restart: unless-stopped
|