通过docker-compose.yml文件一次性安装mysql、minio、redis服务

1. 创建统一目录(确保路径存在)

复制代码
# 创建 /opt/stack 及子目录,匹配 Compose 文件中的挂载路径

mkdir -p /opt/stack/{mysql,minio/data,redis/data}

2. 保存 Compose 文件

复制代码
# 直接写入文件(避免手动编辑出错)

cat > /opt/stack/docker-compose.yml <<'EOF'
# Docker Compose 版本(3.8 兼容主流 Docker 版本,适配 19.03+)
version: "3.8"

# 自定义网络:隔离三个服务,避免与其他容器网络冲突
networks:
  stack-network:
    driver: bridge

# 服务定义
services:
  # ===================== MySQL 服务 =====================
  mysql:
    # 镜像版本:与原 docker run 一致(8.0.39)
    image: mysql:8.0.39
    # 容器名称:与原 docker run 一致(vm_mysql01)
    container_name: vm_mysql01
    # 重启策略:与原 docker run 一致(always,容器退出始终自动重启)
    restart: always
    # 端口映射:与原 docker run 一致(宿主机3306映射容器3306)
    ports:
      - "3306:3306"
    # 环境变量:与原 docker run 一致(root密码123456)
    environment:
      - MYSQL_ROOT_PASSWORD=123456
    # 数据卷挂载:将原命名卷 mysql-data 改为绑定 /opt/stack/mysql 目录
    # 统一存储到 /opt/stack/ 下,替代 Docker 自动管理的命名卷
    volumes:
      - /opt/stack/mysql:/var/lib/mysql
    # 归属自定义网络
    networks:
      - stack-network
    # 兼容原 MySQL 8.0 客户端认证方式(避免旧客户端连接失败)
    command: ["--default-authentication-plugin=mysql_native_password"]

  # ===================== MinIO 服务 =====================
  minio:
    # 镜像版本:与原 docker run 一致(RELEASE.2025-04-22T22-12-26Z)
    image: minio/minio:RELEASE.2025-04-22T22-12-26Z
    # 容器名称:与原 docker run 一致(vm_minio01)
    container_name: vm_minio01
    # 重启策略:与原 docker run 隐含的 always 对齐(异常自动重启)
    restart: always
    # 端口映射:与原 docker run 一致(9000=API端口,9001=控制台端口)
    ports:
      - "9000:9000"
      - "9001:9001"
    # 环境变量:与原 docker run 一致(账号admin,密码admin123456)
    environment:
      - MINIO_ROOT_USER=admin
      - MINIO_ROOT_PASSWORD=admin123456
    # 数据卷挂载:将原 /opt/minio/data 改为 /opt/stack/minio/data
    # 统一存储到 /opt/stack/ 下,保持路径逻辑一致
    volumes:
      - /opt/stack/minio/data:/data
    # 归属自定义网络
    networks:
      - stack-network
    # 启动命令:与原 docker run 一致(指定存储目录和控制台端口)
    command: server /data --console-address ":9001"

  # ===================== Redis 服务 =====================
  redis:
    # 镜像版本:与原 docker run 一致(6.2.6)
    image: redis:6.2.6
    # 容器名称:与原 docker run 一致(vm_redis)
    container_name: vm_redis
    # 重启策略:与原 docker run 一致(always)
    restart: always
    # 端口映射:与原 docker run 一致(宿主机6379映射容器6379)
    ports:
      - "6379:6379"
    # 内存限制:与原 docker run 的 -m 256m 一致
    mem_limit: 256m
    # 数据卷挂载:将原 /opt/redis/data 改为 /opt/stack/redis/data
    # 统一存储到 /opt/stack/ 下
    volumes:
      - /opt/stack/redis/data:/data
    # 归属自定义网络
    networks:
      - stack-network
    # 启动命令:与原 docker run 完全一致(开启AOF、内存限制、淘汰策略)
    command:
      - redis-server
      - --appendonly yes          # 开启AOF持久化(与原命令一致)
      - --maxmemory 200mb         # 最大内存限制200MB(与原命令一致)
      - --maxmemory-policy allkeys-lru  # 内存满时淘汰最少使用的key(与原命令一致)
EOF

3. 启动所有服务

复制代码
# 进入 /opt/stack 目录

cd /opt/stack

# 后台启动所有服务(自动拉取镜像、创建容器、挂载数据卷)

docker compose up -d

4. 验证服务是否启动成功

复制代码
# 查看容器状态(所有服务应为 Up 状态)

docker compose ps

# 验证 MySQL 连接

mysql -h127.0.0.1 -uroot -p123456 -e "select 1;"

# 验证 MinIO 健康状态

curl -s http://127.0.0.1:9000/minio/health/live

# 验证 Redis 连接

docker exec -it vm_redis redis-cli ping

日常运维命令

复制代码
# 进入 /opt/stack 目录执行以下命令

cd /opt/stack

# 停止所有服务(保留数据)

docker compose stop

# 启动所有服务

docker compose start

# 重启所有服务

docker compose restart

# 查看某个服务的日志(如 MySQL)

docker compose logs -f mysql

# 升级服务(拉取最新镜像并重启)

docker compose pull && docker compose up -d

# 彻底删除容器(保留 /opt/stack 下的数据)

docker compose down

注意事项

  1. 首次启动时,Docker 会自动拉取对应版本的镜像,若网络较慢可耐心等待;
  2. /opt/stack/ 目录下的所有数据会持久化存储,删除容器不会丢失数据;
  3. 若需修改密码 / 端口 / 参数,直接编辑 docker-compose.yml 后执行 docker-compose up -d 即可热更新;
  4. 生产环境建议将 restart: always 改为 restart: unless-stopped(手动停止后不会自动重启,更安全)。
相关推荐
Dying.Light14 小时前
Linux部署问题
linux·运维·服务器
S190114 小时前
Linux的常用指令
linux·运维·服务器
萤丰信息15 小时前
AI 筑基・生态共荣:智慧园区的价值重构与未来新途
大数据·运维·人工智能·科技·智慧城市·智慧园区
小义_15 小时前
【RH134知识点问答题】第7章 管理基本存储
linux·运维·服务器
运维小欣15 小时前
Agentic AI 与 Agentic Ops 驱动,智能运维迈向新高度
运维·人工智能
_运维那些事儿16 小时前
VM环境的CI/CD
linux·运维·网络·阿里云·ci/cd·docker·云计算
Trouvaille ~17 小时前
【Linux】UDP Socket编程实战(一):Echo Server从零到一
linux·运维·服务器·网络·c++·websocket·udp
嵌入小生00717 小时前
Shell | 命令、编程及Linux操作系统的基本概念
linux·运维·服务器
-Try hard-18 小时前
Linuv软件编程 | Shell命令
linux·运维·服务器
释怀不想释怀18 小时前
Linux快捷键,软件安装启动
linux·运维·服务器