7.狂神说java-docker-compose

docker-compose

回想一下我们之前使用docker 的步骤,手动编写dockerfile,手动的build镜像,然后手动的run起来,都是手动的过程,如果微服务有很多,比如超过100个,那这个过程就变成了灾难了。如果微服务之间有依赖关系就更麻烦了,那么compose就来了!
Compose是用于定义和运行多容器Docker应用程序的工具。通过Compose,您可以使用YAML文件来配置应用程序的服务。然后,使用一个命令,就可以从配置中创建并启动所有服务。
在这里插入图片描述

狂神理解

Compose是Docker官方的开源项目,需要安装。
dockerfile让程序在任何地方运行(有docker环境的)。
compose实例:web服务+redis服务,设置了link,打通了网络,

version: "3.8"
services:
  web:
    build: .
    ports:
      - "5000:5000"
    volumes:
      - .:/code
      - logvolume01:/var/log
    links:
      - redis
  redis:
    image: redis
volumes:
  logvolume01: {}

用上面的这种方式,哪怕你有一百个服务,配置好了之后,也可以一句话启动:docker compose up。
compose的重要概念:

  • service:容器,应用,项目的一个部分。
  • project:一组关联的容器,构成了项目。

安装

1.下载

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

但是上面这个地址太慢了,换我们国内的镜像

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

2.授权

$ sudo chmod +x /usr/local/bin/docker-compose

3.创建软连接,方便全局调用

$ sudo ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose

4.测试是否安装成功

$ docker-compose --version
cker-compose version 1.24.1, build 4667896b

Docker-Compose管理MySQL和Tomcat容器

yml文件以key:value方式指定配置信息
多个配置信息以换行+缩进的方式来区分
docker-compose.yml文件中,不要使用制表符
关键词:后面都是有一个空格的,比如:restart: always

以一个管理mysql+tomcat的yaml的容器为例

version:'3.1'
services:
  mysql:                     # 服务的名称
    restart: always          # 代表只要Docker启动,那么这个容器就跟着一起启动
    image: daocloud.io/library/mysql:5.7.4     # 指定镜像路径
    container_name: mysql    # 指定容器名称
    ports:
      - 3306:3306        # 指定端口号的映射
    environment:
      MYSQL_ROOT_PASSWORD: root         # 指定MySQL的ROOT用户登录密码
      TZ: Asia/Shanghai                 # 指定时区
    volumes:
      - /opt/docker_mysql-tomcat/mysql_data:/var/lib/mysql        # 映射数据卷
  tomcat:
    restart: always          # 代表只要Docker启动,那么这个容器就跟着一起启动
    image: daocloud.io/library/tomcat:8.5.15-jre8     # 指定镜像路径
    container_name: tomcat    # 指定容器名称
    ports:
      - 8080:8080        # 指定端口号的映射
    environment:
      MYSQL_ROOT_PASSWORD: root         # 指定MySQL的ROOT用户登录密码
      TZ: Asia/Shanghai                 # 指定时区
    volumes:
      - /opt/docker_mysql-tomcat/tomcat_webapps:/usr/local/tomcat/webapps        # 映射数据卷
      - /opt/docker_mysql-tomcat/tomcat_logs:/usr/local/tomcat/logs        # 映射数据卷

常用管理命令总结

 # 1. 基于docker-compose.yml启动管理的容器
docker-compose up -d
# 2. 关闭并删除容器
docker-compose down
# 3. 开启|关闭|重启已经存在的由docker-compose维护的容器
docker-compose start|stop|restart
# 4. 查看由docker-compose管理的容器
docker-compose ps
# 5. 查看日志
docker-compose logs -f

docker-compose配合Dockerfile使用

使用docker-compose.yml文件以及Dockerfile文件在生成自定义镜像的同时启动当前镜像,并且由docker-compose去管理容器
docker-compose.yml:

# yml文件
version: '3.1'
services:
  ssm:
    restart: always
    build:                           # 构建自定义镜像
      context: ../                   # 指定Dockerfile文件所在路径
      dockerfile: Dockerfile         # 指定Dockerfile文件名称
    image: ssm:1.0.1
    container_name: ssm
    ports:
      8081:8080
    environment:
      TZ: Asia/Shanghai

Dockerfile文件:

from daocloud.io/library/tomcat:8.5.15-jre8
copy ssm.war /usr/local/tomcat/webapps

在Dockerfile文件所在的目录下,启动

# 可以直接启动基于docker-compose.yml以及Dockerfile文件构建的自定义镜像
docker-compose up -d
# 如果自定义镜像不存在,会帮助我们构建出自定义镜像,如果自定义镜像已经存在,会直接运行这个自定义镜像
# 重新构建的话
# 重新构建自定义镜像
docker-compose build
# 运行前,重新构建
docker-compose up -d --build

官方快速开始demo

https://www.runoob.com/docker/docker-compose.html
官方demo流程如下:
在这里插入图片描述
启动compose文件的流程如下:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
观察一下在这个过程中我们构建的镜像:
在这里插入图片描述
docker 没有使用swarm是不能使用service命令的。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

命名的规则:yml文件名-yml文件中的服务名-num,其中num为副本数量,因为docker真正的用处在于集群使用的场景,肯定不止是一个应用的,是多个,所以num作为副本数量就很重要了。

3.网络规则

在这里插入图片描述
run起来之后,会自动构建一个网络,如上图。命名与yml文件的名字有关。
如果10个服务属于一个项目,那该项目中内容应该在同一个网络中。就可以通过域名访问。
查看该网络的细节:inspect
在这里插入图片描述
如果在同一个网络下,可以通过域名访问。服务挂了,再启动一个就是了。
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

yaml规则

官网:https://docs.docker.com/compose/compose-file/
注意compose高版本是向下兼容的。
简单理解分为3层:

version: '' # 版本
services: 
  服务1: web
    # 服务配置
    images
    build
    network
    ...
  服务2: 
  服务3:
 
# 其他配置:网络/卷/全局规则
volumes:
networks:
configs:
 

学习compose:
1.官方文档
2.使用yaml的一键启动的开源项目

实例:一键部署博客

这也是docker官方提供的例子
https://docs.docker.com/compose/wordpress/

在这里插入图片描述

-d 就是后台启动

实战

1.搞一个springboot项目,勾选redis的jar包。注意用idea生成骨架会有一个jar包打包不把依赖包打进去的坑,自己百度解决一下就行了。
地址:https://blog.csdn.net/ityqing/article/details/85000302
在这里插入图片描述

2.配置属性文件
在这里插入图片描述

3.编写dockerfile
在这里插入图片描述

4.编写docker-compoose.yaml

在这里插入图片描述
5.丢到服务器,然后docker-compose up -d

在这里插入图片描述

在这里插入图片描述

如果一次性没运行起来,那么需要重新构建,使用下面的命令:
在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值