Compose

官方编排工具。简单来说就是项目部署。详情可以参考之前的文章Docekr三剑客之 Docekr compose

一、安装和卸载

1.1 安装

在 Linux 上的也安装十分简单,从 GitHub Release 处直接下载编译好的二进制文件即可。
例如,在 Linux 64 位系统上直接下载对应的二进制包。

// 先把docker-compose文件dump到当前目录
wget https://github.com/docker/compose/releases/download/v2.12.2/docker-composelinux-x86_64
// 然后拷贝到/usr/bin/
$ sudo cp -arf docker-compose-linux-x86_64 /usr/bin/docker-compose
$ sudo chmod +x /usr/bin/docker-compose

1.2 卸载

如果是二进制包方式安装的,删除二进制文件即可。

sudo rm /usr/bin/docker-compose

二、实战部署

2.1 下载代码

git clone https://gitee.com/nickdemo/helloworld.git

2.2 在同一级目录下创建Dockerfile.compose文件

vim Dockerfile.compose
FROM golang:1.18
ADD ./helloworld /go/src/helloworld/
WORKDIR /go/src/helloworld
RUN go env -w GOPROXY=$http_proxy
RUN CGO_ENABLE=0 GOOS=linux GOARCH=amd64 go build -o app .

FROM ubuntu:latest
COPY ./helloworld/curl-amd64 /usr/bin/curl
RUN chmod +x /usr/bin/curl
ENV env1=env1value
ENV env2=env2value
WORKDIR /app/
COPY --from=0 /go/src/helloworld/app ./
EXPOSE 80
ENTRYPOINT ["./app"]
CMD ["--param1=p1","--param2=p2"]

2.3 在同一级目录下创建docker-compose.yaml文件

vim docker-compose.yaml
version: '3.7'
# 定义项目中的服务
services:
  # 名为web的服务
  web:
    # 根据配置构建镜像
    build:
      # 构建镜像的上下文
      context: .
      # 构建镜像的dockerfile
      dockerfile: Dockerfile.compose
      # 构建参数
      args:
        http_proxy: https://proxy.golang.com.cn,https://goproxy.cn,direct
      # 设置labels元数据
      labels:
        myhello: 1.0
        com.example.description: "Accounting webapp"
      # 为构建的镜像指定tags
      tags:
      - "myhello:1.0.0"
      - "localhost:5000/myhello:1.0.0"
    # 指定容器名称
    container_name: "myweb"
    # 设置容器依赖关系,表示web服务依赖于redis服务
    depends_on:
    - redis
    # 运行容器的端口映射
    ports:
    - "80:80"
    # 覆盖容器的cmd指令
    command: ["--param1=1","--param2=2"]
    # 设置环境变量
    environment:
      env1: "a"
      env2: "b"
    # 健康检查
    healthcheck:
      # 检查命令
      #test: ["CMD","curl","http://localhost/health"] 
      test: ["CMD-SHELL","statuscode=`curl -o /dev/null -s -w %{http_code} http://localhost/health`; [ $$statuscode -le 400 ] || exit 1"]
      # 检查时间间隔
      interval: 5s
      # 检查超时时间
      timeout: 1s
      # 重试次数,即连续失败指定次数则判定为不健康
      retries: 5
      # 设置容器初始化时间,再次期间不报告健康检查状态
      start_period: 5s
    # 使用定义的网络
    networks:
    - mynetwork
    - net1
  # 名为 redis的服务
  redis:
    # 服务启动镜像
    image: "redis:latest"
    container_name: "myredis"
    # 容器暴露端口
    expose:
    - 6379
    # 指定容器启动命令,即覆盖cmd指令
    command: redis-server --requirepass 123456
    # 数据卷设置
    volumes:
    - /data
    networks:
    - mynetwork
    - net2
# 定义网络
networks:
  net1: {}
  net2: {}
  mynetwork:
    ipam:
      driver: default
      config:
      - subnet: "172.16.238.0/24"

2.4 验证docker-compose.yaml文件正确性

注意: 以下 docker-compose 命令都是在项目目录下,否则就需要指定相关配置文件。

docker-compose -f docker-compose.yaml config

如果config命令原样输出配置文件,就说明配置文件没有问题了。

2.5 启动应用程序

建议在项目文件夹下操作docker-compose,否则就需要显式指定项目名称和配置文件了。启动前确定配置文件中的端口没有被占用。

docker-compose up -d

2.6 查看容器名称和服务名称

myredis 和 myweb 是容器的名字,docker-compose 操作的对象是服务(redis、web)。

docker-compose ps

docker二进制安装 docker组 二进制部署docker_redis


验证服务是否正常运行,返回ok即正常运行

curl http://localhost/health

docker二进制安装 docker组 二进制部署docker_docker二进制安装 docker组_02

查看日志 操作的对象就是服务了web 或 redis

docker二进制安装 docker组 二进制部署docker_运维_03

验证redis服务,通过 key value 设置键值对,再通过key获取对应的值。

docker二进制安装 docker组 二进制部署docker_redis_04


docker二进制安装 docker组 二进制部署docker_docker_05


进入到redis容器,也能成功查看name的值。

docker二进制安装 docker组 二进制部署docker_docker二进制安装 docker组_06

2.7 重新编译

修改配置文件以及代码后需要重新编译,可以使用–no-cahe 指定不需要使用缓存。

docker-compose build --no-cache

docker二进制安装 docker组 二进制部署docker_docker_07

2.8 重启项目

docker-compose restart

docker二进制安装 docker组 二进制部署docker_redis_08

容器呢,不会因为你重新编译了新镜像,就去更换启动镜像。除非down掉,再up。

2.9 关闭项目

docker-compose down

docker二进制安装 docker组 二进制部署docker_redis_09

2.10 停止及启动指定服务

docker-compose stop 

docker-compose start server_name

如果不指定服务名,默认停止/启动所有服务。

docker二进制安装 docker组 二进制部署docker_linux_10