赞
踩
目录
随着应用架构的不段复杂和微服务的应用,通常在一个系统中需要包含多个模块,而一般情况下这些模块都会被部署到不同的 Docker 容器中。如果每一个模块都通过手动方式来完成部署,则效率是非常低,且也不利于系统的维护和扩展。
因此我们需要一个能够方便地定义,管理(编排)我们复杂的容器的工具,他就是我们接下来要说的Docker Compose。他是一个服务编排工具,可以很方便的帮助我们对容器进行定义和编排,他不是通过shell脚本命令,而是通过yml描述语言来完成。
Docker Compose的github地址:GitHub - docker/compose: Define and run multi-container applications with Docker
Docker官方文档地址:Docker Compose overview | Docker Documentation
官方定义Docker Compose:Compose 是一个用于定义和运行多容器 Docker 应用程序的工具。通过 Compose,您可以使用 YAML 文件来配置应用程序的服务。然后,使用单个命令,您可以根据配置创建并启动所有服务。
当前Github最新release地址为2.20.2版本。推荐使用2.x版本,因为官方已经表明v1版本将在2023-07起停止更新,将在新版的Docker中不再可用,而V2版本包含在所有当前支持的Docker版本中。
我这边下载的版本为2.16.0版本。
官方文档中也有详细的安装步骤。Overview | Docker Documentation。
官方有2种安装方式,一种是独立安装Compose,另一种是安装Compose插件。采用插件安装是在我们已有的Docker引擎上完成Compose安装。这里我们采用插件方式安装:
1)首先我们下载安装Docker Compose:
sudo curl -SL https://github.com/docker/compose/releases/download/v2.20.2/docker-compose-linux-x86_64 -o /usr/local/bin/docker-compose
如果curl很慢,也可以手动下载文件,然后上传上来。然后cp到/usr/local/bin/docker-compose下。
2)接下来要给当前文件赋予执行(+x)权限:
chmod + x /usr/local/bin/docker-compose
3)查看dockerf compose版本:
docker-compose --version
这样便安装成功了。
以前面我们联系的镜像myapp为例。
首先编制Dockerfile文件:
- FROM openjdk:8
-
- # 执行维护者的信息
- MAINTAINER shamee csdn peng793049488
-
- # 创建一个存放该工程的目录
- RUN mkdir -p /data/project
- COPY myapp.jar /data/project/myapp.jar
-
- # 对外暴露一个8899端口
- EXPOSE 8899
-
- # 执行启动
- ENTRYPOINT ["/bin/sh", "-c", "java -jar /data/project/myapp.jar"]
其次,构建镜像:
docker build -t myapp .
最后,启动容器:
docker run -d -p 18080:8080 myapp
查看执行结果:
1)同样编制好Dockerfile文件:
- FROM openjdk:8
-
- # 执行维护者的信息
- MAINTAINER shamee csdn peng793049488
-
- # 创建一个存放该工程的目录
- RUN mkdir -p /data/project
- COPY myapp.jar /data/project/myapp.jar
-
- # 对外暴露一个8899端口
- EXPOSE 8899
-
- # 执行启动
- ENTRYPOINT ["/bin/sh", "-c", "java -jar /data/project/myapp.jar"]
2)接着,在目录下创建“docker-compose.yml”文件:
touch docker-compose.yml
并输入以下内容:
- version: '3'
- services:
- myapp:
- build: .
- ports:
- - "18080:8080"
3)启动应用:
docker-compose up
初次启动,会经历镜像构建比较慢:
构建结束后,会启动该容器:
来访问下页面,页面结果是一样的:
通过docker compose部署的应用,我们可以使用相应命令查看镜像,和容器信息等。
查看容器。
- docker-compose ps
- # 查看全部容器
- docker-compose ps -a
查看镜像。
当启动一些模块的时候,比如依赖于其他模块的优先启动,可以使用depends_on。比如一个web应用模块启动之前,db模块必须先启动。则在docker-compose.yml中可以指定这种顺序:
- version: '3'
- services:
- myapp:
- image: httpd
- depends_on:
- - db
- db:
- image: centos
设置指定运行容器的个数,动态进行扩容和缩容。
- # 扩容到3个示例
- docker-compose scale myapp=3
docker compose相关参数还有很多,今天这里只是介绍了几个常用的参数以及命令。使用compose重点在于docker-compose.yml的配置管理,以后会慢慢接触到。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。