docker-compose安装部署和使用

docker-compose 是用于定义和运行多容器 Docker 应用程序的工具。通过 Compose,您可以使用 YML 文件来配置应用程序需要的所有服务。然后,使用一个命令,就可以从 YML 文件配置中创建并启动所有服务
1.docker-compose安装
github上下载二进制文件,根据操作系统架构选择
在这里插入图片描述

https://github.com/docker/compose/releases/download/v2.29.7/docker-compose-linux-aarch64

只需要放入/usr/local/bin/ 路径下并重新命名添加可执行权限

mv docker-compose-linux-aarch64 docker-compose
chmod +x docker-compose

2.dockr-compose命令

docker-compose up

用于部署一个 Compose 应用
默认情况下该命令会读取名为 docker-compose.yml 或 docker-compose.yaml 的文件
当然用户也可以使用 -f 指定其他文件名。通常情况下,会使用 -d 参数令应用在后台启动

docker-compose stop

停止 Compose 应用相关的所有容器,但不会删除它们
被停止的应用可以很容易地通过 docker-compose restart 命令重新启动

docker-compose rm

用于删除已停止的 Compose 应用
它会删除容器和网络,但是不会删除卷和镜像

docker-compose restart

重启已停止的 Compose 应用

docker-compose ps

用于列出 Compose 应用中的各个容器
输出内容包括当前状态、容器运行的命令以及网络端口

docker-compose down

停止并删除运行中的 Compose 应用

它会删除容器和网络,但是不会删除卷和镜像

接下来进入实战

创建一个名为 docker-compose.yml 的文件,部署redis

```bash
version: '3.8'

services:
  redis:
    image: redis
    container_name: redis
    restart: always
    sysctls:
      net.core.somaxconn: 1024
    ports:
      - "6379:6379"
    volumes:
      - /data/redis/redis.conf:/etc/redis/redis.conf
      - /data/redis/log/:/var/log/redis/
      - /data/redis/data:/data
    command: ["redis-server", "/etc/redis/redis.conf", "--appendonly", "yes", "--requirepass", "密码"]

运行以下命令启动服务:

docker-compose up -d

进入容器

docker-compose exec redis /bin/bash

创建一个名为 docker-compose.yml 的文件,部署nginx

version: '3.8'

services:
  nginx:
    image: nginx
    container_name: nginx
    ports:
      - "18088:80"
    volumes:
      - /etc/localtime:/etc/localtime
      - /data/nginx/conf/:/etc/nginx
      - /data/nginx/dist/:/data/nginx/html/
      - /data/nginx/logs/:/var/log/nginx/
    tty: true

docker-compose up -d

进入容器

docker-compose exec nginx /bin/bash

如果容器使用的是其他 shell,如 /bin/sh,请相应调整命令。

使用说明:
创建一个名为 docker-compose.yml 的文件,部署minio

version: '3.8'

services:
  minio:
    image: minio/minio:latest
    container_name: minio
    ports:
      - "10087:9000"
      - "10088:9001"
    environment:
      MINIO_ROOT_USER: minioadmin
      MINIO_ROOT_PASSWORD: test@2024
      TZ: Asia/Shanghai
    volumes:
      - /data/minio/data:/data
      - /data/minio/config:/root/.minio
    command: server /data --console-address ":9001" --address ":9000"
    logging:
      driver: local
docker-compose up -d

进入容器

docker-compose exec minio /bin/bash

使用docker stack(堆栈)服务编排

使用 Docker Stack 进行服务编排,你需要创建一个 YAML 文件,定义服务的配置。以下是将你提供的 Redis 配置转换为 Docker Stack YAML 文件的示例:
docker-compose.yml

version: '3.8'  # 指定 Compose 文件的版本

services:
  redis:
    image: redis  # 使用的镜像
    restart: always  # 设置重启策略
    deploy:
      replicas: 1  # 指定副本数量
      resources:
        limits:
          memory: 512M  # 设置内存限制
    ports:
      - "6379:6379"  # 端口映射
    volumes:
      - redis_conf:/etc/redis/redis.conf  # 挂载配置文件
      - redis_log:/var/log/redis/  # 挂载日志目录
      - redis_data:/data  # 挂载数据目录
    sysctls:
      net.core.somaxconn: "1024"  # 设置内核参数
    command: ["redis-server", "/etc/redis/redis.conf", "--appendonly", "yes", "--requirepass", "你的密码"]  # 启动命令

volumes:
  redis_conf:
    driver: local
    driver_opts:
      type: none
      device: /data/redis/redis.conf
      o: bind
  redis_log:
    driver: local
    driver_opts:
      type: none
      device: /data/redis/log/
      o: bind
  redis_data:
    driver: local
    driver_opts:
      type: none
      device: /data/redis/data
      o: bind

部署堆栈
将上述内容保存为 docker-compose.yml 文件。
部署堆栈
在终端中使用以下命令来部署堆栈,命名为 redis_stack:

docker stack deploy -c docker-compose.yml redis_stack

查看服务状态
使用以下命令查看 redis_stack 堆栈及其服务的状态:

docker stack services redis_stack

删除堆栈
如果不再需要堆栈,可以使用以下命令删除它:

docker stack rm redis_stack

这样,你就将堆栈命名为与服务相关的名称 redis_stack 了

Docker Stack 的 docker-compose.yml 格式,并且使用与服务相关的命名,以下是相应的配置nginx示例:
docker-compose.yml

version: '3.8'  # 指定 Compose 文件的版本

services:
  nginx:
    image: nginx  # 使用的镜像
    restart: always  # 设置重启策略
    ports:
      - "18088:80"  # 端口映射
    volumes:
      - /etc/localtime:/etc/localtime  # 挂载本地时间
      - nginx_conf:/etc/nginx  # 挂载配置文件
      - nginx_dist:/data/nginx/html/  # 挂载静态文件
      - nginx_logs:/var/log/nginx/  # 挂载日志目录

volumes:
  nginx_conf:
    driver: local
    driver_opts:
      type: none
      device: /data/nginx/conf/
      o: bind
  nginx_dist:
    driver: local
    driver_opts:
      type: none
      device: /data/nginx/dist/
      o: bind
  nginx_logs:
    driver: local
    driver_opts:
      type: none
      device: /data/nginx/logs/
      o: bind

部署堆栈
在终端中使用以下命令来部署堆栈,命名为 nginx_stack:

docker stack deploy -c docker-compose.yml nginx_stack

查看服务状态
使用以下命令查看 nginx_stack 堆栈及其服务的状态:

docker stack services nginx_stack

删除堆栈
如果不再需要堆栈,可以使用以下命令删除它:

docker stack rm nginx_stack

注意事项
确保宿主机的 /data/nginx/ 目录及其子目录存在,并且具有适当的权限。
确保 /etc/localtime 挂载是正确的,以保证时区一致性。
这样,你就可以通过 Docker Stack 成功管理 Nginx 服务了!

Docker Stack 的 docker-compose.yml 格式,并使用与服务相关的命名,以下是相应的配置minio示例:

docker-compose.yml

version: '3.8'  # 指定 Compose 文件的版本

services:
  minio:
    image: minio/minio:latest  # 使用的镜像
    restart: always  # 设置重启策略
    ports:
      - "10087:9000"  # 映射端口
      - "10088:9001"  # 控制台端口映射
    environment:
      MINIO_ROOT_USER: "minioadmin"  # 设置 MinIO 根用户
      MINIO_ROOT_PASSWORD: "test@2024"  # 设置 MinIO 根密码
      TZ: "Asia/Shanghai"  # 设置时区
    volumes:
      - minio_data:/data  # 挂载数据目录
      - minio_config:/root/.minio  # 挂载配置目录
    deploy:
      restart_policy:
        condition: on-failure  # 设置重启策略为失败重启
    command: server /data --console-address ":9001" --address ":9000"  # 启动命令

volumes:
  minio_data:
    driver: local
    driver_opts:
      type: none
      device: /data/minio/data
      o: bind
  minio_config:
    driver: local
    driver_opts:
      type: none
      device: /data/minio/config
      o: bind

部署堆栈
在终端中使用以下命令来部署堆栈,命名为 minio_stack:

docker stack deploy -c docker-compose.yml minio_stack

查看服务状态
使用以下命令查看 minio_stack 堆栈及其服务的状态:

docker stack services minio_stack

删除堆栈
如果不再需要堆栈,可以使用以下命令删除它:

docker stack rm minio_stack

注意事项
确保宿主机的 /data/minio/ 目录及其子目录存在,并且具有适当的权限。
将 MinIO 的用户名和密码更改为更安全的值,以确保安全性。
这样,你就可以通过 Docker Stack 成功管理 MinIO 服务了!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

❀͜͡傀儡师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值