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
如果一次性没运行起来,那么需要重新构建,使用下面的命令: