通过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(手动停止后不会自动重启,更安全)。
相关推荐
编程小Y5 小时前
Docker常见问题
docker
猫豆~5 小时前
LAMP项目部署——8day
linux·运维·服务器·centos
毕设源码-郭学长5 小时前
【开题答辩全过程】以 基于微服务的网络运维管理系统设计与实现为例,包含答辩的问题和答案
运维·网络·微服务
徐徐图之!5 小时前
二、开始我们的运维之路&运维学习路线
linux·运维·云计算
武帝为此5 小时前
【NGINX 介绍与安装】
运维·nginx
scx_link6 小时前
使用docker安装ollama及ollama拉取模型的总结
运维·docker·容器·ollama
梦里不知身是客116 小时前
FIFO调度器在工作实例中的应用
运维·网络·智能路由器
Warren986 小时前
面试和投简历闲聊
网络·学习·docker·面试·职场和发展·eureka·ansible
徐子元竟然被占了!!6 小时前
Linux-chown
java·linux·运维