Docker容器编排

一、简介和下载安装

1.简介

docker-compose是Docker官方的开源项目,可以管理多个docker容器组成的一个应用。你需要定义一个YAML格式的配置文件docker-compose.yaml,写好多容器之间的调用关系。然后只需要一个命令,就能同时启动或者关闭这些容器。

1.1核心概念:

1.一文件:docker-compose.yml
2.两要素:

  • 服务:一个个应用容器实例,比如订单微服务、库存微服务、mysql容器
  • 工程:由一组关联的应用容器组成的一个完整业务单元,在docker-compose.yml文件中被定义

1.2使用步骤

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

1.3常用命令

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

2.下载说明

地址:https://docs.docker.com/compose/
由于博主使用的是mac系统,下载的Docker Desktop自带docker-compose,故而不用安装,其他平台的用户可以点击下面的链接,里面会有详细的安装说明!
Docker容器编排_第1张图片

二、具体实操

1.不使用docker-compose的情况

如果不使用docker-compose,我们部署一个微服务一般需要下面的几步:

1.新建mysql容器实例,并创建用到的数据库表
2.新建redis容器实例

last:新建微服务工程实例

上述的操作可以看我前面的博客,很明显可以看出上面的操作存在很多问题:

1.容器启动的先后顺序要求固定,先mysql+redis才能启动为服务
2.多个run命令
3.容器的启停或宕机,有可能导致ip地址对应的容器实例变化,映射出错,要么生产ip写死(不推荐),要么通过服务调用

2.使用docker-compose

2.1编写docker-compose.yml

#docker-compose文件的版本,目前使用的是官网提供的最新版本3
version: "3"
#关于服务容器实例的配置 
services:
 #---------------第一个容器服务的配置-----------------------	
  microService: #自定义的服务名,可随意
    image: docket-test:1.1 #需要启动的docker容器名称及版本号
    container_name: ms01 #容器运行后的名称,相当于 --name命令
    #build:#构建指定目录下的Dockerfile
      #context: .
      #dockerfile: Dockerfile
    ports: #启动后的端口映射
      - "6001:6001"
    volumes:#容器数据卷的映射配置,相当于参数命令 -v
      - ~/microService/data:/data #容器数据卷的映射路径
    networks: #自定义的网络配置相当于参数 --network
      - wf_net #自定义的网络,通过 docker network create命令创建
    depends_on: #image配置项启动前需要先启动的容器实例,也就是docket-test启动前 
      - redis #需要先启动 redis 和mysql,此处使用的是下面自定义的容器服务名
      - mysql
 #---------------第二个容器服务的配置-----------------------	
  redis:  #自定义的服务名,可随意
    image: redis:6.0.8  #需要启动的docker容器名称及版本号
    ports:
      - "6379:6379"  #启动后的端口映射
    volumes: #容器数据卷的映射配置,相当于参数命令 -v
      - ~/redis/redis.conf:/etc/redis/redis.conf
      - ~/redis/data:/data
    networks: #自定义的网络配置相当于参数 --network
      - wf_net 
    command: redis-server /etc/redis/redis.conf # 使用redis.conf运行redis
    
  #---------------第三个容器服务的配置-----------------------	
  mysql:#自定义的服务名,可随意
    image: mysql:5.7 #需要启动的docker容器名称及版本号
    environment:#环境配置
      MYSQL_ROOT_PASSWORD: 'root' #root用户的密码
      MYSQL_ALLOW_EMPTY_PASSWORD: 'no' #是否允许空密码
      MYSQL_DATABASE: 'docker-test' 
      MYSQL_USER: 'lzl' #对mysql再配置一个用户名
      MYSQL_PASSWORD: 'lzl123'#对mysql再配置一个m
    ports: #启动后的端口映射
       - "3306:3306"
    volumes: #容器数据卷的映射配置,相当于参数命令 -v
       - ~/mysql/db:/var/lib/mysql
       - ~/mysql/conf/my.cnf:/etc/my.cnf
       - ~/mysql/init:/docker-entrypoint-initdb.d
    networks: #自定义的网络配置相当于参数 --network
      - wf_net 
    command: --default-authentication-plugin=mysql_native_password #解决外部无法访问
 
networks: #网络配置,此处相当于再此处创建网络
   wf_net: #相当于通过 docker network create命令创建一个wf_net网络

2.2修改微服务的配置信息并重新构建镜像

2.2.1改用服务名代替ip的写法!
Docker容器编排_第2张图片
2.2.2maven打包并上传到服务器

#打包成jar
mvn clean install package -Pdev
#上传服务器
rsync 本地文件地址 root@服务器IP:服务器目录地址
#当Dockerfile和jar包上传到服务器的指定目录后,使用下面的命令进行构建镜像
docker build -t docker-test:1.1 .

2.3一键运行

此时目录下一句有下面的三个文件,在该目录下去执行下面的命令:
在这里插入图片描述

#检查yml文件的语法
docker-compose config -q
#启动
docker-compose up

在这里插入图片描述
当出现上面的几个done说明启动成功后,再进入mysql容器中建立数据库表即可收功!!!

docker exec -it mysqlid bash
mysql -ulzl -plzl123
....

你可能感兴趣的:(docker,docker,容器,运维)