• docker入门加实战—项目部署之DockrCompose


    docker入门加实战—项目部署之DockrCompose

    我们部署一个简单的java项目,可能就包含3个容器:

    • MySQL
    • Nginx
    • Java项目

    而稍微复杂的项目,其中还会有各种各样的其它中间件,需要部署的东西远不止3个。如果手动的逐一部署,就太麻烦了,同时也无法保证完整性。

    而Docker Compose就可以帮助我们实现多个相互关联的Docker容器的快速部署。它允许用户通过一个单独的 docker-compose.yml 模板文件(YAML 格式)来定义一组相关联的应用容器。

    基本用法

    docker-compose.yml文件的基本语法可以参考官方文档:

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

    docker-compose文件中可以定义多个相互关联的应用容器,每一个应用容器被称为一个服务(service)。由于service就是在定义某个应用的运行时参数,因此与docker run参数非常相似。

    举例来说,用docker run部署MySQL的命令如下:

    docker run -d \
      --name mysql \
      -p 3306:3306 \
      -e TZ=Asia/Shanghai \
      -e MYSQL_ROOT_PASSWORD=123 \
      -v ./mysql/data:/var/lib/mysql \
      -v ./mysql/conf:/etc/mysql/conf.d \
      -v ./mysql/init:/docker-entrypoint-initdb.d \
      --network sjdwz_network
      mysql
    

    如果用docker-compose.yml文件来定义,就是这样:

    version: "3.8"
    
    services:
      mysql:
        image: mysql
        container_name: mysql
        ports:
          - "3306:3306"
        environment:
          TZ: Asia/Shanghai
          MYSQL_ROOT_PASSWORD: 123
        volumes:
          - "./mysql/conf:/etc/mysql/conf.d"
          - "./mysql/data:/var/lib/mysql"
        networks:
          - new
    networks:
      new:
        name: sjdwz_network
    

    为了方便写路径,把我们的dokcerFIle文件和jar包放到/root目录;

    目录

    /root/sjdwz_demo里的文件我们就不使用了。

    我们的项目部署compose文件如下:

    version: "3.8"
    
    services:
      mysql:
        image: mysql
        container_name: mysql
        ports:
          - "3306:3306"
        environment:
          TZ: Asia/Shanghai
          MYSQL_ROOT_PASSWORD: 123
        volumes:
          - "./mysql/conf:/etc/mysql/conf.d"
          - "./mysql/data:/var/lib/mysql"
          - "./mysql/init:/docker-entrypoint-initdb.d"
        networks:
          - sjdwz-new-network
      sjdwzinstance:
        build: 
          context: .
          dockerfile: Dockerfile
        container_name: sjdwzinstance
        ports:
          - "8080:8080"
        networks:
          - sjdwz-new-network
        depends_on:
          - mysql
      nginx:
        image: nginx
        container_name: nginx
        ports:
          - "18080:18080"
        volumes:
          - "./nginx/nginx.conf:/etc/nginx/nginx.conf"
          - "./nginx/html:/usr/share/nginx/html"
        depends_on:
          - sjdwzinstance
        networks:
          - sjdwz-new-network
    networks:
      sjdwz-new-network:
        name: sjdwz-new-network
    

    基础命令

    编写好docker-compose.yml文件,就可以部署项目了。常见的命令:

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

    基本语法如下:

    docker compose [OPTIONS] [COMMAND]
    

    其中,OPTIONS和COMMAND都是可选参数,比较常见的有:

    类型 参数或指令 说明
    Options -f 指定compose文件的路径和名称
    -p 指定project名称。project就是当前compose文件中设置的多个service的集合,是逻辑概念
    Commands up 创建并启动所有service容器
    down 停止并移除所有容器、网络
    ps 列出所有启动的容器
    logs 查看指定容器的日志
    stop 停止容器
    start 启动容器
    restart 重启容器
    top 查看运行的进程
    exec 在指定的运行中容器中执行命令

    把我们的dockerCompose文件放到/root目录;

    上传文件的位置

    # 1.进入root目录
    cd /root
    
    # 2.删除旧容器
    docker rm -f $(docker ps -qa)
    
    # 3.删除sjdwzservice镜像
    docker rmi sjdwzservice
    
    # 4.清空MySQL数据
    rm -rf mysql/data
    
    # 5.启动所有, -d 参数是后台启动;没有-f文件是因为我们的compose文件就在这里,名字也是叫docker-compose.yml,所以不用加
    docker compose up -d
    

    运行截图

    查看镜像

    docker compose images
    

    查看镜像

    访问如下

    访问成功

  • 相关阅读:
    全面解析HTTP协议
    策略模式详解+代码案例
    pytest多进程/多线程执行测试用例
    pcl--第十节 点云曲面重建
    搞个微信小程序001
    11. 常用类
    rabbitmq资料汇总
    RabbitMQ 模拟实现【四】:虚拟主机设计
    【MySQL】深入理解MySQL索引优化器原理(MySQL专栏启动)
    Scala---元组
  • 原文地址:https://www.cnblogs.com/nicaicai/p/17783316.html