Docker Compose
# 什么是 DockerCompose
- Docker Compose 可以基于 Compose 文件帮我们快速的部署分布式应用,而无需手动一个个创建和运行容器!
- Compose 文件是一个文本文件,通过指令定义集群中的每个容器如何运行。
version: "3.8"
services:
mysql:
image: mysql:5.7.25
environment:
MYSQL_ROOT_PASSWORD: 123
volumes:
- "/tmp/mysql/data:/var/lib/mysql"
- "/tmp/mysql/conf/hmy.cnf:/etc/mysql/conf.d/hmy.cnf"
web:
build: .
ports:
- "8090:8090"
mysql 没有暴露端口是因为 mysql 仅供微服务访问,无需对外暴露
DockerCompose 的详细语法参考官网:https://docs.docker.com/compose/compose-file/
# 安装
# 下载
方法一:
# 安装
curl -L https://github.com/docker/compose/releases/download/1.23.1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
方法二:
将 docker-compose
文件上传到 /usr/local/bin/
目录
# 提权
chmod +x /usr/local/bin/docker-compose
# Base 自动补全命令
curl -L https://raw.githubusercontent.com/docker/compose/1.29.1/contrib/completion/bash/docker-compose > /etc/bash_completion.d/docker-compose
出现错误
如果这里出现错误,需要修改自己的 hosts 文件:
echo "199.232.68.133 raw.githubusercontent.com" >> /etc/hosts
# 案例:部署微服务
NipGeihou/docker-compose-demo 实现思路如下:
- 查看课前资料提供的 cloud-demo 文件夹,里面已经编写好了
docker-compose
文件 - 修改自己的 cloud-demo 项目,将数据库、nacos 地址都命名为 docker-compose 中的服务名
- 使用 maven 打包工具,将项目中的每个微服务都打包为 app.jar
- 将打包好的 app.jar 拷贝到 cloud-demo 中的每一个对应的子目录中
- 将 cloud-demo 上传至虚拟机,利用
docker-compose up -d
来部署- up: 创建并启动容器
启动可能出现因无法连接 nacos 导致的微服务启动失败,需先启动 nacos 再启动微服务容器
上次更新: 2023/06/02, 23:30:21