1.提出问题

1.Docker部署需要一个个手动部署麻烦 Docker Compose可以基于Compose文件帮我们快速的部署分布式应用

2.Docker-Compose

1.Docker-Compose概述

:::info Docker Compose可以基于Compose文件帮我们快速的部署分布式应用,而无需手动一个个创建和运行容器! :::

2.Compose文件格式

语法官网

  1. version: "3.8"
  2. services:
  3. mysql:
  4. image: mysql:5.7.25
  5. environment:
  6. MYSQL_ROOT_PASSWORD: 123
  7. volumes:
  8. - "/tmp/mysql/data:/var/lib/mysql"
  9. - "/tmp/mysql/conf/hmy.cnf:/etc/mysql/conf.d/hmy.cnf"
  10. web:
  11. build: .
  12. ports:
  13. - "8090:8090"

说明

:::success 上面的Compose文件就描述一个项目,其中包含两个容器:

  • mysql:一个基于mysql:5.7.25镜像构建的容器,并且挂载了两个目录
  • web:一个基于docker build临时构建的镜像容器,映射端口时8090

其实DockerCompose文件可以看做是将多个docker run命令写到一个文件,只是语法稍有差异。 :::

3.安装DockerCompose

安装链接

4.部署微服务集群

image.png

1.实现思路

:::info 1.创建空文件夹,并在空文件夹里编写docker-compose文件
2.在空文件夹里面创建服务的文件夹并在每个文件夹里编写Dockerfile文件
3.修改java项目,将数据库、nacos地址都命名为docker-compose中的服务名
4.使用maven打包工具,将项目中的每个微服务都打包为app.jar
5.将打包好的app.jar拷贝到文件夹中的每一个对应的子目录中
6. 将文件夹上传至虚拟机,利用 docker-compose up -d 来部署 :::

2.docker-compose文件格式

version: "3.2"

services:
  nacos:
    image: nacos/nacos-server
    environment:
      MODE: standalone
    ports:
      - "8848:8848"
  mysql:
    image: mysql:5.7.25
    environment:
      MYSQL_ROOT_PASSWORD: 123
    volumes:
      - "$PWD/mysql/data:/var/lib/mysql"
      - "$PWD/mysql/conf:/etc/mysql/conf.d/"
  userservice:
    build: ./user-service
  orderservice:
    build: ./order-service
  gateway:
    build: ./gateway
    ports:
      - "10010:10010"

说明

:::success 其中包含5个service服务

  • nacos:作为注册中心和配置中心
    • image: nacos/nacos-server: 基于nacos/nacos-server镜像构建
    • environment:环境变量
      • MODE: standalone:单点模式启动
    • ports:端口映射,这里暴露了8848端口
  • mysql:数据库
    • image: mysql:5.7.25:镜像版本是mysql:5.7.25
    • environment:环境变量
      • MYSQL_ROOT_PASSWORD: 123:设置数据库root账户的密码为123
    • volumes:数据卷挂载,这里挂载了mysql的data、conf目录,其中有我提前准备好的数据
  • userservice、orderservice、gateway:都是基于Dockerfile临时构建的 :::

    3.Dockerfile文件格式

    FROM java:8-alpine
    COPY ./app.jar /tmp/app.jar
    ENTRYPOINT java -jar /tmp/app.jar
    

    4..java项目的mysql、nacos地址都修改为基于容器名的访问。

    spring:
    datasource:
      url: jdbc:mysql://mysql:3306/cloud_order?useSSL=false
      username: root
      password: 123
      driver-class-name: com.mysql.jdbc.Driver
    
    application:
      name: orderservice
    cloud:
      nacos:
        server-addr: nacos:8848 # nacos服务地址
    

    5.修改工程打包名称

    <build>
    <!-- 服务打包的最终名称 -->
    <finalName>app</finalName>
    <plugins>
      <plugin>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-maven-plugin</artifactId>
      </plugin>
    </plugins>
    </build>
    

    5.Docker镜像仓库

    1.搭建私有镜像仓库

    :::info 搭建镜像仓库可以基于Docker官方提供的DockerRegistry来实现。 ::: 官网

    1.简化版镜像仓库命令

    docker run -d \
      --restart=always \
      --name registry    \
      -p 5000:5000 \
      -v registry-data:/var/lib/registry \
      registry
    

    2.带有图形化界面镜像仓库

    :::info 1.mkdir registry-ui 创建registry-ui文件夹
    2.touch docker-compose.yml 文件夹里创建docker-compose文件
    3.把可视化代码复制到文件中
    4.在文件目录下docker-compose up -d 启动 :::

    version: '3.0'
    services:
    registry:
      image: registry
      volumes:
        - ./registry-data:/var/lib/registry
    ui:
      image: joxit/docker-registry-ui:static
      ports:
        - 8080:80
      environment:
        - REGISTRY_TITLE=传智教育私有仓库
        - REGISTRY_URL=http://registry:5000
      depends_on:
        - registry
    

    注意:配置Docker信任地址

    :::success 私服采用的是http协议,默认不被Docker信任,所以需要做一个配置: :::

    # 打开要修改的文件
    vi /etc/docker/daemon.json
    # 添加内容:
    "insecure-registries":["http://192.168.163.140:5000"]
    # 重加载
    systemctl daemon-reload
    # 重启docker
    systemctl restart docker
    

    2.推送、拉取镜像

    :::info 推送镜像到私有镜像服务必须先tag,步骤如下:
    ① 重新tag本地镜像,名称前缀为私有仓库的地址:192.168.163.130:5000/
    docker tag nginx:latest 192.168.163.130:5000/nginx:1.0
    ② 推送镜像
    docker push 192.168.163.130:5000/nginx:1.0
    ③ 拉取镜像
    docker pull 192.168.163.130:5000/nginx:1.0
    设置容器开启自启
    docker update —restart=always 容器名称 :::

    6.常用命令

    常用命令 :::info docker-compose 命令 —help 获得一个命令的帮助
    docker-compose up -d nginx 构建启动nignx容器
    docker-compose exec nginx bash 登录到nginx容器中
    docker-compose down 此命令将会停止 up 命令所启动的容器,并移除网络
    docker-compose ps 列出项目中目前的所有容器
    docker-compose restart nginx 重新启动nginx容器
    docker-compose build nginx 构建镜像
    docker-compose build —no-cache nginx 不带缓存的构建
    docker-compose top 查看各个服务容器内运行的进程
    docker-compose logs -f nginx 查看nginx的实时日志
    docker-compose images 列出 Compose 文件包含的镜像
    docker-compose config 验证文件配置,当配置正确时,不输出任何内容,当文件配置错误,输出错误信息。
    docker-compose events —json nginx 以json的形式输出nginx的docker日志
    docker-compose pause nginx 暂停nignx容器
    docker-compose unpause nginx 恢复ningx容器
    docker-compose rm nginx 删除容器(删除前必须关闭容器,执行stop)
    docker-compose stop nginx 停止nignx容器
    docker-compose start nginx 启动nignx容器
    docker-compose restart nginx 重启项目中的nignx容器 :::