DockerCompose - 容器编排、模板命令、compose命令、Pottainer 可视化界面管理(一文通关)

目录

一、DockerCompose 容器编排

1.1、简介

1.2、Docker-Compose 安装

1.2.1、在线安装

1.2.2、离线安装

1.3、docker-compose.yml 中的模板命令

前置说明

模板命令

1.4、DockerCompse 命令

前置说明

up

down

exec

ps

restart

rm

top

pause暂停 和 unpause恢复

logs

二、Pottainer Docker 可视化界面

2.1、简介

2.2、使用


一、DockerCompose 容器编排


1.1、简介

a)为什么使用 DockerCompose?(纯 Docker 进行项目部署存在问题)

  • 容器编排:例如,一个完整的微服务项目势必会用到多个容器进行配置,而这多个容器之间也会存在某种依赖,也就是说某些容器运行需要其他容器优先启动之后才能正常运行,这就需要使用 DockerCompose 进行容器编排.
  • 方便部署:纯 Docker 部署,需要将一个项目涉及到的 N 多个容器进行一一部署,因此日后如果需要进行多个服务器部署就会显得相当麻烦.  而使用 DockerCompose 只需要一条命令即可解决.

b)什么是 DockerCompose?

Compose 的定位就是对多个 Docker 容器的管理,也就是说对 项目 所涉及到的所有容器整合到一起,对这组容器进行按照指定顺序启动.

c)如何使用 DockerCompose?

首先明白以下两个概念:

  • 项目:由一组管理的服务(容器)组成的一个完整的业务单元,在 docker-compose.yml 文件中定义.
  • 服务:一个项目中的某个容器就是一个服务.

因此,我们只需要在 docker-compose.yml 文件中编写容器编排,之后就可以通过 DockerCompose 提供的相关命令对此文件进行操作,进而实现容器编排.

1.2、Docker-Compose 安装

Tip:只有 Linux 平台上安装 Docker 时不会自动安装 DockerCompose。Windows、Macos 安装 Docker 时会自动安装 DockerCompose.

1.2.1、在线安装

a)在线安装 DockerCompose 

# 安装
curl -L https://github.com/docker/compose/releases/download/1.23.1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose

b)修改权限

# 修改权限
chmod +x /usr/local/bin/docker-compose

1.2.2、离线安装

a)下载 docker-compose 脚本

b)放入 /usr/local/bin 目录下.

c)修改权限:chmod +x /usr/local/bin/docker-compose

1.3、docker-compose.yml 中的模板命令

前置说明

docker-compose.yml 文件一般分成两个部分,一个部分使用来说明当前 DockerCompose 文件的版本(不同版本语言大同小异).  另一个部分就是进行容器编排的.

a)指定版本:docker-compose.yml 文件的第一个命令一般都是用于指定当前 DockerCompose 文件的版本。

可以先通过命令查看自己 DockerCompose 的版本.

可以对应下标找到自己的版本(官网也有) 

Compose file format Docker Engine release
Compose specification 19.03.0+
3.8 19.03.0+
3.7 18.06.0+
3.6 18.02.0+
3.5 17.12.0+
3.4 17.09.0+
3.3 17.06.0+
3.2 17.04.0+
3.1 1.13.1+
3.0 1.13.0+

因此我这里就是用 3.5 就ok,那么对应的 docker-compose.yml 文件如下

version: "3.5"

b)容器编排:例如需要编排一个 tomcat:8.0 的镜像.

# 版本
version: "3.5"

# 管理服务
services:

  tomcat: # 自定义服务名称(id)
    image: tomcat:8.0 # 基于哪个镜像
    ports: # 映射 宿主机:容器 端口
      - 8080:8080

以上只是给出一个小示例,下文中会具体讲到~

模板命令

以下 docker-compose.yml 文件中包含了所有常用的模板命令.

# 版本
version: "3.5"

# 声明使用网桥
networks:
  cyk:

# 声明别名数据卷
volumes:
  mysqlData:

# 管理服务
services:

  apps: # 自定义服务id
#    container_name: web_apps # a.指定 name(不推荐使用)
    build: # 1.根据 Dockerfile 构建镜像,并启动容器
      context: ./ # 用来指定 Dockerfile 上下文目录
      dockerfile: Dockerfile # 指定 Dockerfile 文件名称
    ports: # 2.映射端口
      - "8081:8081"
#    expose: # b.暴露端口(不建议使用)
#      - 8081
    depends_on: # 3.依赖服务
      - mysql #这里就是指在 mysql 启动之后再启动当前服务
    # command: ["test.jar"] # 4.覆盖启动容器后的命令(覆盖CMD)
    networks: # 5.指定网桥
      - cyk # 这个网桥需要声明才能使用

  mysql:
    image: mysql:5.7 # 6.指定启动镜像
    ports:
      - "3306:3306"
    # environment: # 7.配置环境变量(适用于保密性不高的参数)
      # 两种写法(推荐字符串形式)
      # MYSQL_ROOT_PASSWORD: root
      # - "MYSQL_ROOT_PASSWORD=root"
    env_file: # 8.配置环境变量(适用于保密性高的参数,例如 MySQL 数据库密码)
      - ./.env
    volumes: # 9.数据卷映射
      - mysqlData:/var/lib/mysql # 别名数据卷需要声明(例如此处的 mysqlData)
    restart: always # 10.指定服务启动时机(always 表示 docker 启动就立即启动)

常用模板指令解释:

  1. build:指定需要根据哪个 Dockerfile 文件构建镜像(通过 context 参数指定上下文目录;通过 dockerfile 参数指定 Dockerfile 文件),并运行.
  2. ports:指定宿主机和容器端口的映射,相当于 docker run -p 
  3. depends_on:指定当前容器依赖于哪个容器,被依赖的容器会先启动(解决服务的先后启动问题).
  4. command:覆盖 dockerfile 文件中的 CMD 指令.
  5. networks:指定启动容器使用的网桥(需要有声明).
  6. image:指定启动容器使用的镜像是谁,相当于 docker run image(镜像名).
  7. environment:指定容器启动时的环境变量,相当于 docker run -e 选项(适用于密保性不高的参数).
  8. env_file:指定容器启动时的环境变量,相比于 environment 参数,此命令指定的是一个文件(文件中包含环境变量值),并且建议文件名为 .env (适用于保密性高的参数,例如 MySQL 数据库密码).
  9. volumes:指定宿主机和容器数据卷的映射,相当于 docker run -v
  10. restart:指定当前服务的运行情况,例如 always 表示跟随 docker 引擎的启动而启动,相当于 docker run --restart=always

不推荐使用的模板指令解释:

a. container_name:指定 docker-compose 启动容器名称(不推荐原因:写死容器名后,不利于后期修改维护).

b.expose:指定暴露的端口号(不推荐原因:expose 一般都写在 Dockerfile 文件中,不需要再 docker-compose.yml 文件中重复声明).

1.4、DockerCompse 命令

前置说明

docker-compose 命令语法如下:

docker-compose 命令 项目|服务id

docker-compose 命令如果没有指定 服务id,默认是对整个项目的操作!

Ps:docker-compose 中只需要重点掌握 up 和 down 就可以,因为其他指令基本都可以通过 docker 原生命令解决~

up

此命令十分强大,它将禅师自动完成构建镜像、(重新)创建服务、启动服务,并关联服务相关容器的一系列操作(简单来说就是按照 docker-compose.yml 文件内容来启动项目).

# 启动整个项目
docker-compose up
# 启动 docker-compose.yml 文件中对应 服务id 的容器
docker-compose up 服务id

down

关闭所有容器,并移除网络.

# 关闭整个项目
docker-compose down
# 关闭指定服务
docker-compose down 服务id

exec

进入某个服务内部.

docker-compose exec 服务id bash

ps

列出所有运行的服务.

docker-compose ps

restart

重启整个项目或指定服务.

# 重启整个项目
docker-compose restart
# 重启指定服务
docker-compose restart 服务id
# 通过 -t 参数指定重启前停止容器的超时时间(默认是 10s),例如指定超时时间为 20s
docker-compose restart -t 20 服务id

rm

删除整个项目或者指定服务.

# 整个项目
docker-compose rm
# 删除指定服务
docker-compose rm 服务id
# 强制删除
docker-compose rm -f 服务id
# 删除容器所挂载的数据卷
docker-compose rm -v 服务id

top

查看整个项目中所有服务容器内运行进程,或者查看某个指定服务的容器的进程.

docker-compose top 服务id

pause暂停 和 unpause恢复

暂停或者恢复整个项目所有服务或者指定服务.

docker-compose pause|unpause 服务id

logs

查看整个项目中所有服务运行日志,或者指定服务的运行日志.

# 通过 -f 参数可以达到实时监控的效果
docker-compose logs -f 服务id

二、Pottainer Docker 可视化界面


2.1、简介

第三方公司开源 Portainer 项目,用来对 docker 引擎中运行所有容器进行可视化展示和管理.

2.2、使用

直接使用以下命令拉取并运行:

docker run -d -p 8000:8000 -p 9000:9000 --name=portainer --restart=always -v /var/run/docker/sock:/var/run/docker.sock -v portainer_data:/dataportainer/portainer

8080 端口映射的是 docker 引擎,方便拉取 docker 镜像,容器的运行的数据.

9090 端口就是我们可以访问的可视化界面.

DockerCompose - 容器编排、模板命令、compose命令、Pottainer 可视化界面管理(一文通关)_第1张图片

你可能感兴趣的:(Docker,docker,容器,服务器,docker-compose)