docker-compose是Docker官方的开源项目,可以管理多个docker容器组成的一个应用。你需要定义一个YAML格式的配置文件docker-compose.yaml
,写好多容器之间的调用关系。然后只需要一个命令,就能同时启动或者关闭这些容器。
1.一文件:
docker-compose.yml
2.两要素:
- 服务:一个个应用容器实例,比如订单微服务、库存微服务、mysql容器
- 工程:由一组关联的应用容器组成的一个完整业务单元,在
docker-compose.yml
文件中被定义
1.编写Dockerfile定义各个微服务应用并构建出对应的镜像文件
2.使用docker-compose.yml
定义一个完整的业务单元,安排好整体应用中的各个容器服务。
3.最后,执行docker-compose up
命令来启动并运行整个应用程序,完成一键部署上线
#查看帮助
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
地址:https://docs.docker.com/compose/
由于博主使用的是mac系统,下载的Docker Desktop
自带docker-compose,故而不用安装,其他平台的用户可以点击下面的链接,里面会有详细的安装说明!
如果不使用docker-compose
,我们部署一个微服务一般需要下面的几步:
1.新建mysql容器实例,并创建用到的数据库表
2.新建redis容器实例
…
last:新建微服务工程实例
上述的操作可以看我前面的博客,很明显可以看出上面的操作存在很多问题:
1.容器启动的先后顺序要求固定,先mysql+redis才能启动为服务
2.多个run命令
3.容器的启停或宕机,有可能导致ip地址对应的容器实例变化,映射出错,要么生产ip写死(不推荐),要么通过服务调用
#docker-compose文件的版本,目前使用的是官网提供的最新版本3
version: "3"
#关于服务容器实例的配置
services:#---------------第一个容器服务的配置----------------------- microService: #自定义的服务名,可随意image: docket-test:1.1 #需要启动的docker容器名称及版本号container_name: ms01 #容器运行后的名称,相当于 --name命令#build:#构建指定目录下的Dockerfile#context: .#dockerfile: Dockerfileports: #启动后的端口映射- "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:/datanetworks: #自定义的网络配置相当于参数 --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再配置一个mports: #启动后的端口映射- "3306:3306"volumes: #容器数据卷的映射配置,相当于参数命令 -v- ~/mysql/db:/var/lib/mysql- ~/mysql/conf/my.cnf:/etc/my.cnf- ~/mysql/init:/docker-entrypoint-initdb.dnetworks: #自定义的网络配置相当于参数 --network- wf_net command: --default-authentication-plugin=mysql_native_password #解决外部无法访问networks: #网络配置,此处相当于再此处创建网络wf_net: #相当于通过 docker network create命令创建一个wf_net网络
2.2.1改用服务名代替ip的写法!
2.2.2maven打包并上传到服务器
#打包成jar
mvn clean install package -Pdev
#上传服务器
rsync 本地文件地址 root@服务器IP:服务器目录地址
#当Dockerfile和jar包上传到服务器的指定目录后,使用下面的命令进行构建镜像
docker build -t docker-test:1.1 .
此时目录下一句有下面的三个文件,在该目录下去执行下面的命令:
#检查yml文件的语法
docker-compose config -q
#启动
docker-compose up
当出现上面的几个done
说明启动成功后,再进入mysql容器中建立数据库表即可收功!!!
docker exec -it mysqlid bash
mysql -ulzl -plzl123
....