docker-compose笔记

Docker Compose 是 Docker 容器进行编排的工具,定义和运行多容器的应用,可以一条命令启动多个容器。

安装:pip install docker-compose
查看是否已安装:docker-compose -v

docker-compoes -h 解释:

build     #构建或重建服务
help      #命令帮助
kill      #杀掉容器
logs      #显示容器的输出内容
port      #打印绑定的开放端口
ps        #显示容器
pull      #拉取服务镜像
restart   #重启服务
rm        #删除停止的容器
run       #运行一个一次性命令
scale     #设置服务的容器数目
start     #开启服务
stop      #停止服务
up        #创建并启动容器


常用命令:

  1. 启动容器,如果镜像不存在则先下载镜像,如果容器没创建则创建容器,如果容器没启动则启动:docker-compose up -d
  2. 停止并移除容器:docker-compose down
  3. 重启服务:docker-compose restart
  4. 构建建启动nignx容器:docker-compose up -d nginx
  5. 登录到nginx容器中:docker-compose exec nginx bash
  6. 删除所有nginx容器,镜像:docker-compose down
  7. 显示所有容器:docker-compose ps
  8. 重新启动nginx容器:docker-compose restart nginx
  9. 在php-fpm中不启动关联容器,并容器执行php -v 执行完成后删除容器:docker-compose run --no-deps --rm php-fpm php -v
  10. 构建镜像:docker-compose build nginx
  11. 不带缓存的构建:docker-compose build --no-cache nginx
  12. 查看nginx的日志 :docker-compose logs nginx
  13. 查看nginx的日志:docker-compose logs -f nginx
  14. 验证(docker-compose.yml)文件配置:docker-compose config -q
  15. 以json的形式输出nginx的docker日志:docker-compose events --json nginx
  16. 暂停nignx容器:docker-compose pause nginx
  17. 恢复ningx容器:docker-compose unpause nginx
  18. 删除容器:docker-compose rm nginx
  19. 停止nignx容器:docker-compose stop nginx
  20. 启动nignx容器:docker-compose start nginx


docker-compose.yml 属性:

docker-compose.yml是Compose的默认模板文件。一份标准配置文件应该包含 version、services、networks 三大部分。该文件有多种写法,例如Version 1 file format、Version 2 file format、Version 2.1 file format、Version 3 file format等。其中,Version 1 file format将逐步被被弃用;Version 2.x及Version 3.x基本兼容,是未来的趋势。

(1) build
配置构建时的选项,Compose会利用它自动构建镜像。build的值可以是一个路径,例如:

build: ./dir

也可以是一个对象,用于指定Dockerfile和参数,例如:

build:
  context: ./dir
  dockerfile: Dockerfile-alternate
  args:
    buildno: 1

(2) command
覆盖容器启动后默认执行的命令。示例:

command: bundle exec thin -p 3000

也可以是一个list,类似于Dockerfile中的CMD指令,格式如下:

command: [bundle, exec, thin, -p, 3000]

(3) dns
配置dns服务器。可以是一个值,也可以是一个列表。示例:

dns: 8.8.8.8
dns:
  - 8.8.8.8
  - 9.9.9.9

(4) dns_search
配置DNS的搜索域名,可以是一个值,也可以是一个列表。示例:

dns_search: example.com
dns_search:
  - dc1.example.com
  - dc2.example.com

(5) environment
环境变量设置,可使用数组或字典两种方式。示例:

environment:
  RACK_ENV: development
  SHOW: 'true'
  SESSION_SECRET:

environment:
  - RACK_ENV=development
  - SHOW=true
  - SESSION_SECRET

(6) env_file
从文件中获取环境变量,可指定一个文件路径或路径列表。如果通过 docker-compose -f FILE 指定了Compose文件,那么env_file中的路径是Compose文件所在目录的相对路径。使用environment指定的环境变量会覆盖env_file指定的环境变量。示例:

env_file: .env

env_file:
  - ./common.env   # 共用
  - ./apps/web.env # web用
  - /opt/secrets.env # 密码用

(7) expose
暴露端口,只将端口暴露给连接的服务,而不暴露给宿主机。示例:

expose:
 - "3000"
 - "8000"

(8) external_links
连接到docker-compose.yml外部的容器,甚至并非Compose管理的容器,特别是提供共享或公共服务的容器。格式跟links类似,例如:

external_links:
 - redis_1
 - project_db_1:mysql
 - project_db_1:postgresql

(9) image
指定镜像名称或镜像id,如果本地不存在该镜像,Compose会尝试下载该镜像。
示例:

image: java

(10) links
连接到其他服务的容器。可以指定服务名称和服务别名( SERVICE:ALIAS ),也可只指定服务名称。例如:

web:
  links:
   - db
   - db:database
   - redis

(11) networks
详见本书《Docker Compose网络设置》一节。
(12) network_mode
设置网络模式。示例:

network_mode: "bridge"
network_mode: "host"
network_mode: "none"
network_mode: "service:[service name]"
network_mode: "container:[container name/id]"

(13) ports
暴露端口信息,可使用HOST:CONTAINER 的格式,也可只指定容器端口(此时宿主机将会随机选择端口),类似于docker run -p 。
需要注意的是,当使用HOST:CONTAINER 格式映射端口时,容器端口小于60将会得到错误的接口,因为yaml会把xx:yy 的数字解析为60进制。因此,建议使用字符串的形式。示例:

ports:
 - "3000"
 - "3000-3005"
 - "8000:8000"
 - "9090-9091:8080-8081"
 - "49100:22"
 - "127.0.0.1:8001:8001"
 - "127.0.0.1:5000-5010:5000-5010"

(14) volumes
卷挂载路径设置。可以设置宿主机路径 (HOST:CONTAINER) ,也可指定访问模式 (HOST:CONTAINER:ro)。示例:

volumes:
  # 仅仅指定一个路径引擎会创建一个卷
  - /var/lib/mysql

  # 指定绝对路径映射
  - /opt/data:/var/lib/mysql

  # 相对路径映射(相对于docker-compose.yml文件)
  - ./cache:/tmp/cache

  # 用户相对路径
  - ~/configs:/etc/configs/:ro

  # 指定卷名
  - datavolume:/var/lib/mysql

(15) volumes_from
从另一个服务或容器挂载卷。可指定只读(ro)或读写(rw),默认是读写(rw)。示例:

volumes_from:
 - service_name
 - service_name:ro
 - container:container_name
 - container:container_name:rw

(16) docker-compose.yml文件示例:


version: "3"
services:
 
  redis:
    image: redis:alpine
    ports:
      - "6379"
    networks:
      - frontend
    deploy:
      replicas: 2
      update_config:
        parallelism: 2
        delay: 10s
      restart_policy:
        condition: on-failure
 
  db:
    image: postgres:9.4
    volumes:
      - db-data:/var/lib/postgresql/data
    networks:
      - backend
    deploy:
      placement:
        constraints: [node.role == manager]
 
  vote:
    image: dockersamples/examplevotingapp_vote:before
    ports:
      - 5000:80
    networks:
      - frontend
    depends_on:
      - redis
    deploy:
      replicas: 2
      update_config:
        parallelism: 2
      restart_policy:
        condition: on-failure
 
  result:
    image: dockersamples/examplevotingapp_result:before
    ports:
      - 5001:80
    networks:
      - backend
    depends_on:
      - db
    deploy:
      replicas: 1
      update_config:
        parallelism: 2
        delay: 10s
      restart_policy:
        condition: on-failure
 
  worker:
    image: dockersamples/examplevotingapp_worker
    networks:
      - frontend
      - backend
    deploy:
      mode: replicated
      replicas: 1
      labels: [APP=VOTING]
      restart_policy:
        condition: on-failure
        delay: 10s
        max_attempts: 3
        window: 120s
      placement:
        constraints: [node.role == manager]
 
  visualizer:
    image: dockersamples/visualizer:stable
    ports:
      - "8080:8080"
    stop_grace_period: 1m30s
    volumes:
      - "/var/run/docker.sock:/var/run/docker.sock"
    deploy:
      placement:
        constraints: [node.role == manager]
 
networks:
  frontend:
  backend:
 
volumes:
  db-data:
docker

我来吐槽

*

*

仅有 1 条评论