docker-compose
介绍与安装
微服务架构的应用系统中一般包含若干个微服务,每个微服务一般都会部署多个实例,如果每个微服务都要手动启停,维护的工作量会很大。
Docker Compose是一个编排多容器分布式部署的工具,提供命令集管理容器化应用的完整开发周期,包括服务构建,启动和停止。使用步骤:
1. 利用 Dockerfile 定义运行环境镜像
2. 使用 docker-compose.yml
定义组成应用的各服务
3. 运行 docker-compose up
启动应用
下载: https://github.com/docker/compose/releases/
这里选择1.25.4版本下载,下载下来的就是一个可执行文件,赋予执行权限,可以将其移动到/usr/bin
目录下:
wget https://github.com/docker/compose/releases/download/1.25.4/docker-compose-Linux-x86_64
chmod +x docker-compose-Linux-x86_64
mv docker-compose-Linux-x86_64 /usr/bin/docker-compose
查看版本
docker-compose -version
使用
创建一个docker-compose
目录用于测试
mkdir ~/docker-compose
cd ~/docker-compose
编写 docker-compose.yml 文件:
version: '3'
services: # 代表要启动的容器
nginx:
image: nginx
ports:
- 80:80
links:
- app
volumes:
- ./nginx/conf.d:/etc/nginx/conf.d
app:
image: app
expose:
- "8080"
执行命令
docker-compose up
即可运行。
docker私有仓库
Docker官方的Docker hub(https://hub.docker.com)是一个用于管理公共镜像的仓库,我们可以从上面拉取镜像 到本地,也可以把我们自己的镜像推送上去。但是,有时候我们的服务器无法访问互联网,或者你不希望将自己的镜像放到公网当中,那么我们就需要搭建自己的私有仓库来存储和管理自己的镜像。
私有仓库搭建
# 1、拉取私有仓库镜像
docker pull registry
# 2、启动私有仓库容器
docker run -id --name=registry -p 5000:5000 registry
打开浏览器 输入地址 http://私有仓库服务器ip:5000/v2/_catalog ,看到{"repositories":[]}
表示私有仓库 搭建成功
3、修改daemon.json
vim /etc/docker/daemon.json
在上述文件中添加一个key,保存退出。此步用于让 docker 信任私有仓库地址;注意将私有仓库服务器ip修改为自己私有仓库服务器真实ip
{"insecure-registries":["私有仓库服务器ip:5000"]}
4、重启docker 服务
systemctl restart docker
docker start registry
将镜像上传至私有仓库
# 1、标记镜像为私有仓库的镜像
docker tag centos:7 私有仓库服务器IP:5000/centos:7
# 2、上传标记的镜像
docker push 私有仓库服务器IP:5000/centos:7
从私有仓库拉取镜像
# 拉取镜像
docker pull 私有仓库服务器ip:5000/centos:7
原创文章,作者:彭晨涛,如若转载,请注明出处:https://www.codetool.top/article/docker-compose%e4%bd%bf%e7%94%a8%e5%92%8cdocker%e7%a7%81%e6%9c%89%e4%bb%93%e5%ba%93%e6%90%ad%e5%bb%ba/