Docker-compose 简单介绍

server/2024/9/23 14:36:06/

目录

一      Docker-compose与  Docker Swarm

docker-compose%C2%A0%E5%87%BA%E7%8E%B0%E7%9A%84%E6%84%8F%E4%B9%89-toc" style="margin-left:80px;">1,docker-compose 出现的意义

2,  Docker Compose 是什么

3,Docker Swarm    是什么

3,Docker Compose     Docker Swarm  主要区别

二     Docker-compose 简介

1, Docker-compose 组成

2,Docker-compose  的配置文文件

3,Docker-compose 工作原理

 三      compose 安装

1,Docker Compose 环境安装

2, 演示

四     YAML 文件格式及编写注意事项

1, YAML  语言是什么

2,  使用 YAML 时需要注意下面事项

3,    数据结构

3.1   对象映射: 键值对的字典

3.2  序列数组: 一组按次序排列的列表

3.3   布尔值

4    示例

五     Docker Compose配置常用字段

六      Docker Compose 常用命令

七      Docker Compose 文件结构

八    实验模拟   Docker Compose 部署nginx

1,准备依赖文件

2,准备安装包

3,  vim Dockerfile​

4,  编写nginx页面   

docker-compose.yml-toc" style="margin-left:80px;">5,  编写配置文件docker-compose.yml

6,  查看准备环境

docker-compose-toc" style="margin-left:80px;">7, 启动 docker-compose

docker%E5%AE%B9%E5%99%A8%E6%83%85%E5%86%B5-toc" style="margin-left:80px;">8,  查看 docker容器情况

9  ,浏览器访问:http://192.168.217.55:1216

docker-compose%E7%BC%96%E6%8E%92-toc" style="margin-left:40px;">九   nginx + tomcat docker-compose编排

1, 准备tomcat 容器所需的文件  和安装包

dockerfile-toc" style="margin-left:80px;">2, 写 tomcat  容器的 dockerfile

docker-compose.yml-toc" style="margin-left:80px;">3,  修改 docker-compose.yml

docker-compose-toc" style="margin-left:80px;">4, 启动 docker-compose

5,查看容器状态

docker-compose%C2%A0%E6%95%88%E6%9E%9C-toc" style="margin-left:80px;">6,验证 docker-compose 效果

7, 验证是否可以自动获取ip 地址

dockerfile%20compose-toc" style="margin-left:40px;">十    关闭  dockerfile compose

1,会删除 自定义的网络模式

2, 会删除容器

3, 再次开启

十一       报错处理


一      Docker-compose与  Docker Swarm

docker-compose%C2%A0%E5%87%BA%E7%8E%B0%E7%9A%84%E6%84%8F%E4%B9%89">1,docker-compose 出现的意义

我们知道使用一个Dockerfile模板文件可以定义一个单独的应用容器,如果需要定义多个容器就需要服务编排。服务编排有很多种技术方案,今天给大家介绍 Docker 官方产品 Docker Compose 。

Dockerfile可以让用户管理一个单独的应用容器;而Compose则允许用户在一个模板(YAML格式)中定义一组相关联的应用容器(被称为一个 project,即项目),例如一个 Web 服务容器再加上后端的数据库服务容器等。
 

2,  Docker Compose 是什么

Docker Compose 是一个用于定义和运行多容器 Docker 应用程序的工具。它通过一个 YAML 文件(默认为 docker-compose.yml)来定义构成应用程序的多个服务及其网络、卷等依赖关系。使用 Docker Compose 可以通过一个简单的命令(如 docker-compose up)来启动、停止和重建整个应用环境,大大简化了多容器应用的部署和管理流程。Docker Compose 适合于单主机或多主机(但非集群化)环境下的应用部署,适用于开发、测试及小型生产环境。

3,Docker Swarm    是什么

Docker Swarm 是 Docker 官方提供的容器编排工具,用于管理 Docker 容器集群。Swarm 将一组 Docker 引擎(称为节点)组织成一个集群,这些节点可以是物理服务器或虚拟机。在 Swarm 模式下,你可以定义服务(Services),每个服务可以跨越多个节点部署多个实例(Replicas),从而实现高可用性和负载均衡。Swarm 提供了服务发现、负载均衡、故障恢复等功能,并且支持多种调度策略。Swarm 更适用于大型生产环境,特别是需要自动伸缩、滚动更新和复杂服务管理的场景。

3,Docker Compose     Docker Swarm  主要区别

  1. 目标场景:Docker Compose 侧重于单主机或多主机环境下应用的快速部署和配置管理,而 Docker Swarm 则是面向大规模容器集群的编排和管理。

  2. 规模与复杂度:Compoose 适合小型项目或简单的微服务架构,管理相对直接;Swarm 则是为了处理更大规模的服务部署,提供高级功能如跨节点的服务发现、负载均衡和故障转移。

  3. 编排能力:Swarm 提供了更强大的服务编排功能,如自动扩缩容、滚动更新等,而 Compose 缺乏这些高级编排特性。

  4. 配置方式:两者都使用 YAML 文件来定义服务,但 Docker Compose 文件直接描述了服务的配置和依赖关系,而 Docker Swarm 服务定义则嵌入在集群层面的命令或API调用中。

  5. 网络和存储:Swarm 提供了更高级的网络配置选项(如覆盖网络)和数据管理功能,以适应复杂的集群环境。

总的来说,Docker Compose 是一个轻量级的本地开发和小型部署工具,而 Docker Swarm 是一个面向生产环境的容器编排平台,适合构建和管理大型容器化应用。

二     Docker-compose 简介

1, Docker-compose 组成

Docker-Compose将所管理的容器分为三层,分别是工程(project),服务(service)以及容器container)。Docker-Compose运行目录下的所有文件(docker-compose.yml,extends文件或环境变量文件等)组成一个工程,若无特殊指定工程名即为当前目录名。一个工程当中可包含多个服务,每个服务中定义了容器运行的镜像、参数、依赖。一个服务当中可包括多个容器实例,Docker-Compose并没有解决负载均衡的问题,因此需要借助其它工具实现服务发现及负载均衡,比如 Consul

2,Docker-compose  的配置文文件

Docker-Compose的工程配置文件默认为docker-compose.yml,可通过环境变量COMPOSE_FILE或-f参数自定义配置文件,其定义了多个有依赖关系的服务及每个服务运行的容器
 

3,Docker-compose 工作原理

使用一个Dockerfile模板文件,可以让用户很方便的定义一个单独的应用容器。在工作中,经常会碰到需要多个容器相互配合来完成某项任务的情况。例如要实现一个Web项目,除了Web服务容器本身,往往还需要再加上后端的数据库服务容器,甚至还包括负载均衡容器等。

Compose允许用户通过一个单独的docker-compose.yml模板文件(YAML 格式)来定义一组相关联的应用容器为一个项目(project)。

Docker-Compose项目由Python编写,调用Docker服务提供的API来对容器进行管理。因此,只要所操作的平台支持Docker API, 就可以在其上利用Compose来进行编排管理。
 

注:API(全称 Application Programming Interface,中文译为应用程序编程接口,可以把它想象成一套预先设定好的规则或工具箱。这个工具箱能让不同的软件应用程序之间互相“对话”和交换信息。就像是餐厅的菜单,顾客(开发者)不需要知道厨房(底层系统或服务)是如何运作的,只需要根据菜单(API文档)点菜(调用API),厨房就会按要求准备食物(返回数据或执行功能)。)

 三      compose 安装

1,Docker Compose 环境安装

Docker Compose 是 Docker 的独立产品,因此需要安装 Docker 之后在单独安装 Docker Compose

curl -L https://github.com/docker/compose/releases/download/1.21.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose#安装
chmod +x /usr/local/bin/docker-compose
#查看版本
docker-compose --version

2, 演示

查看版本

四     YAML 文件格式及编写注意事项

1, YAML  语言是什么

YAML 是一种标记语言,它可以很直观的展示数据序列化格式,可读性高。类似于 XML数据描述语言,语法比 XML 简单的很多。YAML 数据结构通过缩进来表示连续的项目通过减号来表示键值对用冒号分隔数组用中括号 [] 括起来 hash 用花括号 {} 括起来
 

2,  使用 YAML 时需要注意下面事项

●大小写敏感
●通过缩进表示层级关系
●不支持制表符 tab 键缩进,只能使用空格缩进
●缩进的空格数目不重要,只要相同层级左对齐,通常开头缩进2个空格
●用 # 号注释
●符号字符后缩进1个空格,如冒号 :  、逗号 ,  、横杠 -    
●如果包含特殊字符用单引号('')引起来会作为普通字符串处理,双引号(""): 特殊字符作为本身想表示的意思
name: "Hi,\nTom"
 

3,    数据结构

3.1   对象映射: 键值对的字典

animal: pets    (注意有空格

3.2  序列数组: 一组按次序排列的列表

- Cat
- Dog
- Goldfish
 

["Cat", "Dog", "Goldfish"]            这是第二种写法
 

3.3   布尔值

debug: true
debug: false
 

4    示例

# yaml 格式

用于配置和管理     yaml 是一个简洁的非标记性语言,内容 格式 人性化   较易读


languages:       #序列的映射- Java- Golang- Python
websites:        #映射的映射cpu: 2memory: 1024Mswap: 2048Mdisk: 60G 

 
# Json 格式

主要用于 API接口之间的消息传递

{languages: ['Java','Golang','Python'	],resources: {cpu: '2',memory: '1024M',swap: '2048M',disk: '60G'}
}

 例子3

Baidu:www.baidu.com
wangyi: www.163.com
tengxun: www.qq.com

 

五     Docker Compose配置常用字段

字段描述
build指定 Dockerfile 文件名,要指定Dockerfile文件需要在build标签的子级标签中使用dockerfile标签指定
dockerfile构建镜像上下文路径
context可以是 dockerfile 的路径,或者是指向 git 仓库的 url 地址
image指定镜像
command执行命令,覆盖容器启动后默认执行的命令
container_name指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法scale指定容器数量
deploy指定部署和运行服务相关配置,只能在 Swarm 模式使用
environment添加环境变量
networks加入网络,引用顶级networks下条目
network_mode设置容器的网络模式,如 host,bridge,...
ports暴露容器端口,与 -p 相同,但端口不能低于 60
volumes挂载一个宿主机目录或命令卷到容器,命名卷要在顶级 volumes 定义卷名称
volumes_from从另一个服务或容器挂载卷,可选参数 :ro 和 :rw,仅版本 '2' 支持
hostname容器主机名
sysctls容器内设置内核参数
links连接到另外一个容器,- 服务名称[:服务别名]
privileged用来给容器root权限,注意是不安全的,true | false

restart    
设置重启策略,no,always,nounless-st-failure,oped

no,默认策略,在容器退出时不重启容器

on-failure,在容器非正常退出时(退出状态非0),才会重启容器

on-failure:3,在容器非正常退出时重启容器,最多重启3次。

always,在容器退出时总是重启容器

unless-stopped,在容器退出的容器时总是重启容器,但是不考虑在 Docker 守护进程启动时就已经停止了。

no默认策略,在容器退出时不重启容器
on-failure容器非正常退出时(退出状态非0),才会重启容器
on-failure:3容器非正常退出时重启容器,最多重启3次

always    在容器退出时总是重启容器
unless-stopped    在容器退出的容器时总是重启容器,但是不考虑在 Docker 守护进程启动时就已经停止了
depends_on    在使用Compose时,最大的好处就是少打启动命令,但一般项目容器启动的顺序是有要求的,如果直接从上到下启动容器,可能会因为容器依赖问题而启动失败。

微服务之间也有依赖关系 启动有先后顺序例如在没启动数据库容器的时候启动应用容器,应用容器会因为找不到数据库而退出。depends_on标签用于解决容器的依赖、启动先后的问题。

php:depends_on:- apache- mysql

六      Docker Compose 常用命令

命令含义
build重新构建服务
ps列出容器
up创建和启动容器
exec容器里面执行命令
scale指定一个服务容器启动数量
top显示容器进程
logs查看容器输出
down删除容器、网络、数据卷和镜像
stop/start/restart停止/启动/重启服务

 

七      Docker Compose 文件结构

# 定义 compose 文件的版本号,这里使用的是版本3
version: '3'# services 部分定义了要启动的服务
services:# 定义名为 nginx 的服务nginx:# 设置容器的名字为 web1container_name: web1# 设置容器内的主机名hostname: nginx# build 部分指定了如何构建镜像build:# 指定构建上下文目录,即 Dockerfile 所在目录context: ./nginx# 指定使用的 Dockerfile 文件名dockerfile: Dockerfile# ports 配置服务端口映射ports:# 将容器的80端口映射到宿主机的1216端口- 1216:80# 将容器的443端口映射到宿主机的1217端口- 1217:443# networks 配置容器网络设置networks:# 指定容器加入名为 lnmp 的网络lnmp:# 为容器在 lnmp 网络中指定静态 IPv4 地址ipv4_address: 172.18.0.10# volumes 配置数据卷挂载volumes:# 将宿主机的 ./wwwroot 目录挂载到容器的 /usr/local/nginx/html 目录- ./wwwroot:/usr/local/nginx/html# networks 部分定义了自定义网络
networks:# 定义名为 lnmp 的网络,类型为桥接lnmp:driver: bridge# IPAM (IP Address Management) 配置ipam:config:# 配置网络的子网- subnet: 172.18.0.0/16

八    实验模拟   Docker Compose 部署nginx

1,准备依赖文件

2,准备安装包

在 /opt/compose_nginx/nginx   拖入nginx 安装包

3,  vim Dockerfile

vim Dockerfile
#基于基础镜像
FROM centos:7
#用户信息
MAINTAINER this is nginx image <hmj>
#添加环境包
RUN yum -y update
RUN yum -y install pcre-devel zlib-devel gcc gcc-c++ make
RUN useradd -M -s /sbin/nologin nginx
#上传nginx软件压缩包,并解压
ADD nginx-1.12.0.tar.gz /usr/local/src/
#指定工作目录
WORKDIR /usr/local/src/nginx-1.12.0
RUN ./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module && make && make install
ENV PATH /usr/local/nginx/sbin:$PATH
#指定http和https端口
EXPOSE 80
EXPOSE 443
//方法一:
RUN echo "daemon off;" >> /usr/local/nginx/conf/nginx.conf			#关闭 nginx 在后台运行
#添加宿主机中run.sh到容器中
ADD run.sh /run.sh
RUN chmod 755 /run.sh
CMD ["/run.sh"]
//方法二:
ENTRYPOINT [ "/usr/local/nginx/sbin/nginx", "-g", "daemon off;" ]

4,  编写nginx页面   

docker-compose.yml">5,  编写配置文件docker-compose.yml

version: '3'
services:nginx:container_name: web1hostname: nginxbuild:context: ./nginxdockerfile: Dockerfileports:- 1216:80- 1217:443networks:lnmp:ipv4_address: 172.18.0.10volumes:- ./wwwroot:/usr/local/nginx/html
networks:lnmp:driver: bridgeipam:config:- subnet: 172.18.0.0/16

6,  查看准备环境

准备环境   以做好

docker-compose">7, 启动 docker-compose

去到 docker-compose.yml 所在的目录    启动

docker-compose -f docker-compose.yml up -d
 

-f, --file FILE :使用特定的 compose 模板文件,默认为 docker-compose.yml
-p, --project-name NAME :指定项目名称,默认使用目录名称
-d :在后台运行

docker%E5%AE%B9%E5%99%A8%E6%83%85%E5%86%B5">8,  查看 docker容器情况

 

9  ,浏览器访问:http://192.168.217.55:1216


 

docker-compose%E7%BC%96%E6%8E%92" style="background-color:transparent;">九   nginx + tomcat docker-compose编排

1, 准备tomcat 容器所需的文件  和安装包

dockerfile">2, 写 tomcat  容器的 dockerfile

FROM centos:7
MAINTAINER this is tomcat image <hmj>
ADD jdk-8u291-linux-x64.tar.gz /usr/local/
WORKDIR /usr/local/
RUN mv jdk1.8.0_291  /usr/local/java
ENV JAVA_HOME /usr/local/java
ENV JRE_HOME ${JAVA_HOME}/jre
ENV CLASSPATH .:${JAVA_HOME}/lib:${JRE_HOME}/lib
ENV PATH $JAVA_HOME/bin:$PATH
ADD apache-tomcat-8.5.16.tar.gz /usr/local/
WORKDIR /usr/local/
RUN mv apache-tomcat-8.5.16 /usr/local/tomcat
EXPOSE 8080
#CMD ["/usr/local/tomcat/bin/catalina.sh","run"]
ENTRYPOINT ["/usr/local/tomcat/bin/catalina.sh","run"]
CMD ["/usr/local/tomcat/bin/startup.sh","start"]

docker-compose.yml">3,  修改 docker-compose.yml

version: '3'
services:nginx:container_name: web1hostname: nginxbuild:context: ./nginxdockerfile: Dockerfileports:- 1216:80- 1217:443networks:lnmp:ipv4_address: 172.18.0.10volumes:- ./wwwroot:/usr/local/nginx/htmltomcat:hostname: tomcatbuild:context: ./tomcatdockerfile: Dockerfileports:- 8080:8080networks:lnmp:
networks:lnmp:driver: bridgeipam:config:- subnet: 172.18.0.0/16

为验证 是否可以自动获取ip 地址

docker-compose">4, 启动 docker-compose

5,查看容器状态

docker-compose%C2%A0%E6%95%88%E6%9E%9C">6,验证 docker-compose 效果

7, 验证是否可以自动获取ip 地址

可以!

dockerfile%20compose">十    关闭  dockerfile compose

docker-compose -f docker-compose.yml down

1,会删除 自定义的网络模式

2, 会删除容器

3, 再次开启

容器 网络模式  都会回来   非常方便

十一       报错处理

  docker-compose -f docker-compose.yml up -d  有如下报错

是网络波动   

1,建议把dns  改为本地区dns  

2, 重启 docker

3,  开启路由转发

vim /etc/sysctl.conf
net.ipv4.ip_forward=1sysctl -p
systemctl restart network
systemctl restart docker


http://www.ppmy.cn/server/25046.html

相关文章

Java23种设计模式-行为型模式之责任链模式

责任链模式&#xff08;Chain of Responsibility Pattern&#xff09;:允许将多个对象连接成一条链&#xff0c;并沿着这条链传递一个请求&#xff0c;直到链上的某个对象能够处理该请求为止。这种模式的目的是解耦请求的发送者和接收者&#xff0c;同时允许多个对象有机会处理…

conda修改当前环境中的python版本

1. 首先查看当前的python版本 python -V 2. 进入已经激活的conda环境&#xff0c;搜索库中有无想要的python版本(若有想安装的版本可跳过) conda search --full --name python 3. 安装库中存在且符合要求的python版本即可(以python3.8.1为例) conda install python3.8.1

【酱浦菌-模拟仿真】python模拟仿真PN结伏安特性

PN结的伏安特性 PN结的伏安特性描述了PN结在外部电压作用下的电流-电压行为。这种特性通常包括正向偏置和反向偏置两种情况。 正向偏置 当外部电压的正极接到PN结的P型材料&#xff0c;负极接到N型材料时&#xff0c;称为正向偏置。在这种情况下&#xff0c;外加的正向电压会…

C++笔记:C++中的重载

重载的概念 一.函数重载 代码演示例子&#xff1a; #include<iostream> using namespace std;//函数名相同&#xff0c;在是每个函数的参数不相同 void output(int x) {printf("output int : %d\n", x);return ; }void output(long long x) {printf("outp…

探索银行IT应用系统架构:构建安全高效的金融科技平台

在当今数字化时代&#xff0c;银行业正面临着前所未有的挑战和机遇。作为金融行业的重要组成部分&#xff0c;银行IT应用系统的架构设计至关重要&#xff0c;直接影响着银行的信息化水平、服务效率和安全性。本文将深入探讨典型银行IT应用系统的架构&#xff0c;为银行业构建安…

第二证券投资参考:汽车以旧换新细则发布 云厂商AI投资持续加码

上星期五&#xff0c;A股放量大涨。两市股指盘中单边上行&#xff0c;午后再度攀升&#xff0c;沪指涨超1%&#xff0c;创业板指大涨超3%&#xff1b;到收盘&#xff0c;沪指涨1.17%报3088.64点&#xff0c;深证成指涨2.15%报9463.91点&#xff1b;创业板指涨3.34%报1823.74点&…

玄子Share-Shell编程之条件语句

玄子Share-Shell编程之条件语句 条件测试操作 test命令 测试表达式是否成立&#xff0c;若成立返回0&#xff0c;否则返回其他数值 格式1&#xff1a;test 条件表达式 格式2&#xff1a;[ 条件表达式 ] # 至少应有一个空格文件测试 [ 操作符 文件或目录 ][rootlocal…

CSS 网页布局(详解网页的布局构造)

目录 一、网页布局介绍 1.概念 2.特点 3.好处 二、常见布局概念和技术 三、网格系统布局 1.介绍 2.头部区域 3.菜单导航区域 4.内容区域 4.1.不相等的列 5.底部区域 四、响应式布局实例 五、网页布局结构设计 六、总结 一、网页布局介绍 1.概念 网页布局是将网页内…