10.docker入门到精通—Docker compose 容器编排

一、介绍

Compose 是 Docker 公司推出的一个开源工具软件,可以管理多个Docker 容器组成一个应用。你需要定义一个YAML 格式的配置文件docker-compose.yml,写好多个容器之间的调用关系。然后,只要一个命令,就能同时启动/关闭这些容器。

Compose 允许用户通过一个单独的 docker- compose.yml 模板文件(YAML 格式)来定义一组相关联的应用容器为一个项目(project)。

二、下载

官网

https://docs.docker.com/compose/compose-file/compose-file-v3/

官网下载

https://docs.docker.com/compose/install/

安装(新版docker已经安装了docker-compose,直接docker compose version查看版本)

curl-L"https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)"-o /usr/local/bin/docker-compose

若github下载太慢,可以换源

curl-L https://get.daocloud.io/docker/compose/releases/download/1.28./docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose

修改权限、查看版本

chmod+x /usr/local/bin/docker-compose
docker-compose --version
新版docker使用: docker compose version

卸载

sudorm /usr/local/bin/docker-compose

三、核心概念(一文件、两要素)

1 一文件

docker-compose.yml

2 两要素

2.1 服务(service)

一个个应用容器实例,比如订单微服务、库存微服务、mysql 容器、nginx容器或者 redis 容器

2.2 工程(project)

由一组关联的应用容器组成的一个完整业务单元,在 docker-compose.yml文件中定义。

3 Compose 使用的三个步骤

1.编写 Dockerfile 定义各个微服务应用并构建出对应的镜像文件
2.使用 docker-compose.yml 定义一个完整业务单元,安排好整体应用中的各个容器服务
3.最后执行 docker-compose up 命令 来启动并运行整个应用程序,完成一键部署上线

4 Compose 常用命令

docker compose -h# 查看帮助
docker compose up # 启动所有 docker- compose 服务
docker compose up -d# 启动所有 docker- compose 服务并后台运行
docker compose down # 停止并删除容器、网络、卷、镜像。
docker compose exec yml 里面的服务 id # 进入容器实例内部 docker-compose exec docker- compose.yml 文件中写的服务 id /bin/bash
docker compose ps# 展示当前 docker- compose 编排过的运行的所有容器
docker compose top# 展示当前 docker- compose 编排过的容器进程
docker compose logs yml 里面的服务 id # 查看容器输出日志
docker compose config # 检查配置
docker compose config -q# 检查配置,有问题才有输出
docker compose restart# 重启服务
docker compose start# 启动服务
docker compose stop# 停止服务

5 Compose 编排微服务

5.1 编写 docker-compose.yml 文件

version: "3"

services:
  microService:
    image: zzyy_docker:1.6
    container_name: ms01
    ports:
      -"6001:6001"
    volumes:
      - /app/microService:/data
    networks: 
      - atguigu_net 
    depends_on: 
      - redis
      - mysql

  redis:
    image: redis:6.0.8
    ports:
      -"6379:6379"
    volumes:
      - /app/redis/redis.conf:/etc/redis/redis.conf
      - /app/redis/data:/data
    networks: 
      - atguigu_net
    command: redis-server /etc/redis/redis.conf

  mysql:
    image: mysql:5.7
    environment:
      MYSQL_ROOT_PASSWORD: '123456'
      MYSQL_ALLOW_EMPTY_PASSWORD: 'no'
      MYSQL_DATABASE: 'db2021'
      MYSQL_USER: 'zzyy'
      MYSQL_PASSWORD: 'zzyy123'
    ports:
       -"3306:3306"
    volumes:
       - /app/mysql/db:/var/lib/mysql
       - /app/mysql/conf/my.cnf:/etc/my.cnf
       - /app/mysql/init:/docker-entrypoint-initdb.d
    networks:
      - atguigu_net
    command: --default-authentication-plugin=mysql_native_password #解决外部无法访问

networks: 
   atguigu_net: 

5.2 修改微服务工程

5.2.1 写yml(通过服务名访问,IP无关)
5.2.2 mvn package 命令将微服务形成新的 jar 包,并上传到Linux 服务器/mydocker目录下
5.2.3 编写 Dockerfile
# 基础镜像使用 java
FROM java:8
# 作者

MAINTAINER zzyy
# VOLUME 指定临时文件目录为/tmp,在主
机/var/lib/docker 目录下创建了一个临时文件
并链接到容器的/tmp
VOLUME /tmp

# 将 jar 包添加到容器中并更名为

zzyy_docker.jar
ADD docker_boot-0.0.1-SNAPSHOT.jar
zzyy_docker.jar

# 运行 jar 包

RUN bash-c'touch /zzyy_docker.jar' ENTRYPOINT ["java","-
jar","/zzyy_docker.jar"]
#暴露 6001 端口作为微服务

EXPOSE 6001
5.2.4 构建镜像
docker build -t zzyy_docker:1.6 .

5.3 执行 docker-compose up 或者 执行 docker-compose up -d

5.4 进入mysql容器实例并新建库 db2021 + 新建表 t_user

docker exec -it 容器实例id /bin/bash
mysql -uroot-p
create database db2021;
use db2021;

CREATE TABLE `t_user` (
  `id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
  `username` VARCHAR(50) NOT NULL DEFAULT '' COMMENT '用户名',
  `password` VARCHAR(50) NOT NULL DEFAULT '' COMMENT '密码',
  `sex` TINYINT(4) NOT NULL DEFAULT '0' COMMENT '性别 0=女 1=男 ',
  `deleted` TINYINT(4) UNSIGNED NOT NULL DEFAULT '0' COMMENT '删除标志,默认0不删除,1删除',
  `update_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  `create_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  PRIMARY KEY (`id`)
) ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='用户表';

5.5 测试

5.6 关停

docker compose stop      # 停止服务

猜你喜欢

转载自blog.csdn.net/weixin_54514751/article/details/129683436