docker-compose

本文详细介绍了DockerCompose的原理、yaml配置文件的编写规则,以及如何利用它管理和编排容器,包括服务的定义、依赖关系、网络配置和常用命令的使用。
摘要由CSDN通过智能技术生成

一、docker-compose容器编排的简介

docker-compose 是一个可以实现在单机上对容器集群编排管理的工具。

它允许用户使用docker-compose.yml 配置模板文件来定义应用程序的配置,包括容器的数量、容器之间的依赖关系、环境变量、端口映射以及数据卷等设置。

然后,用户使用docker-compose命令根据指定配置模板文件的配置来启动和管理容器集群。

通过docker-compose的优势:

  1. 使用 Docker Compose命令可以方便地管理多个容器;
  2. 可以解决容器之间的依赖关系,同时启动一个 Web 服务器容器和一个数据库容器,并在它们之间建立网络连接,再通过depends_on实现php依赖于nginx和mysql服务的启动顺序;
  3. Docker Compose 还支持自定义网络,使得容器可以在不同的网络中进行通信;

本质就是在yaml格式的docker-compose配置模板文件里定义多个服务容器的启动参数和依赖关系,并使用docker-compose命令根据指定配置模板文件的配置来启动和管理容器集群。

docker-compose的三大概念
项目project -> 包含一个或多个服务service -> 包含一个或多个容器container的镜像、端口映射、环境变量、依赖关系等启动参数

  1. 默认使用项目的目录名作为project的项目名,支持使用 -p 或 --project-name 来指定项目名称
  2. 项目目录里要包含一个 docker-compose 配置模板文件,默认为 docker-compose.yml,支持使用 -f 或 --file 来指定项目的配置模板文件
  3. 在配置模板文件docker-compose.yaml里要包含一个或多个服务容器的配置,每个服务要包含容器的名称、镜像、映射端口、挂载点、网络模式、依赖关系等容器启动的配置参数

二、docker-compose的使用

1、docker-compose的配置模板文件yaml文件的编写

YAML是一种标记语言,可以很直观的展示数据序列化格式,可读性很高。类似于json数据描述语言,语法比json简单很多,关于yaml数据格式:

  • YAML数据结构通过缩进来表示字段的层级
  • 连续的项目通过减号来表示,
  • 键值对用冒号分隔,
  • 数组用中括号 [] 括起来,
  • hash 用花括号 {} 括起来

关于yaml的注意事项:

  1. 大小写敏感
  2. 通过缩进表示层级关系
  3. 不支持制表符 tab 键缩进,只能使用空格缩进
  4. 缩进的空格数目不重要,只要相同层级左对齐,通常开头缩进2个空格
  5. 用 # 号注释
  6. 符号字符后缩进1个空格,如冒号 :  、逗号 ,  、横杠 - 
  7. 如果包含特殊字符用单引号('')引起来会作为普通字符串处理,双引号(""): 特殊字符作为本身想表示的意思
(1)布尔值类型
debug: true
debug: false
privileged: true
(2)字符串类型
name: tom
name: 'tom'
name: "tom"
(3)一个key有多个值
animal: 
- 飞行动物
- 爬行动物
- 水生动物
- 两栖动物
 
横向格式
animal: ["飞行动物", "爬行动物", "水生动物", "两栖动物"]
(4)对象object类型类型
#yaml格式用 空格缩进 表示字段的层级关系,同一层字段要靠左对齐
 
一级字段:
    二级字段1:                    
    二级字段2:
	    三级字段: 
 
human:
  name:
    姓: "王"
	ming: 
	- 文宇
	- 思聪
  age: 24
  sex: 男
  height: 180
(5)文本块
value:              ->  value: "helloworld"
       hello 
       world
 
 
value: |            -> value: "hello\nworld"              #key: |  表示保留文本块里的换行符
       hello 
       world
 
value: |-           -> value: 相当于 echo -n "helloworld"
       hello        
       world
	   
value: |+           -> value: "hello\nworld\n"
       hello    
       world 
(6)锚点
name: &a yaml       #锚点,相当于 a="yaml"                    
book: *a            #引用,相当于 echo $a     book: yaml   

关于json格式:

 json文件格式:文件名格式通常是以 .json 为后缀,用 大括号{} 表示字段的层级关系,每层字段除了最后一个字段都要用逗号,结尾,特性:易于api接口解析

human:
  name:
    姓: "王"
	ming: 
	- 文宇
	- 思聪
  age: 24
  sex: 男
  height: 180
  
  
{
  "human": {                      #json格式用 大括号{} 表示字段的层级关系,每层字段除了最后一个字段都要用逗号,结尾
     "name": {
	    "姓": ["王"],
		"名":["文宇", "思聪"]
	 },
	 "age": ["24"],
	 "sex": ["男"],
     "height": ["180"]
  
  }
}

2、docker-compose配置模板文件常用的字段 与docker run的选项和参数对比

image  使用本地镜像或从仓库拉取镜像创建容器
build使用dockerfile现场构建镜像创建容器
context指定dockerfile文件所在的目录
dockerfile指定dockerfile的文件名称
command 指定容器启动命令,会覆盖镜像中的CMD指令
container_name 相当于指定容器的名称  --name 
environment  相当于指定容器的环境变量 -e  --env
network_mode相当于指定容器的网络 --network
networks    指定加入的网络和IP    --IP以及自定义网络模式
ports   指定端口映射 -p
volumes  指定数据卷   -v 或者自定义顶级卷(版本3)
volumes_from --volumes-from ,版本3不支持
hostname指定容器的主机名  -h  --hostname
sysctls 指定容器的内核参数  --sysctl
links   指定容器的名称以及连接别名,可以通过容器名称通信 --link
privileged  让容器拥有真正的root权限 不建议使用  不安全 --privileged
restart    

指定重启策略  --restart

设置重启策略,no,always,no-failure,unless-stopped
no,默认策略,在容器退出时不重启容器。
on-failure,在容器非正常退出时(退出状态非0),才会重启容器。
on-failure:3,在容器非正常退出时重启容器,最多重启3次。
always,在容器退出时总是重启容器。
unless-stopped,在容器退出时总是重启容器,但是不考虑在 Docker 守护进程启动时就已经停止了的容器。

depends_on 

指定有依赖关系的容器

在使用Compose时,最大的好处就是少打启动命令,但一般项目容器启动的顺序是有要求的,如果直接从上到下启动容器,可能会因为容器依赖问题而启动失败。例如在没启动数据库容器的时候启动应用容器,应用容器会因为找不到数据库而退出。depends_on标签用于解决容器的依赖、启动先后的问题。
php:
  depends_on:
    - apache
    - mysql

3、docker-compose命令的选项和参数

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

Docker-compose搭建nginx

[root@localhost ~]# cd /usr/local/bin/
[root@localhost bin]# ls
docker-compose
[root@localhost bin]# chmod +x docker-compose
[root@localhost bin]# docker-compose --version
docker-compose version 1.21.1, build 5a3f1a3
[root@localhost ~]# mkdir -p /opt/compose_nginx/nginx /opt/compose_nginx/wwwroot
[root@localhost ~]# cd /opt/compose_nginx/nginx/
[root@localhost nginx]# ls
nginx-1.24.0.tar.gz
[root@localhost nginx]# vim run.sh 
#!/bin/bash
/usr/local/nginx/sbin/nginx

[root@localhost nginx]# vim Dockerfile 
FROM centos:7
MAINTAINER this is nginx image <wx>  #自己定义的名字
RUN yum -y update
RUN yum -y install pcre-devel zlib-devel gcc gcc-c++ make
RUN useradd -M -s /sbin/nologin nginx
ADD nginx-1.24.0.tar.gz /usr/local/src/  #注意 nginx
WORKDIR /usr/local/src/nginx-1.24.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
EXPOSE 80
EXPOSE 443
ADD run.sh /run.sh
RUN chmod 755 /run.sh
CMD ["/run.sh"]

##注释##
#基于基础镜像
FROM centos:7
#用户信息
MAINTAINER this is nginx image <wl>
#添加环境包
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;" ]
[root@localhost nginx]# echo "<h1>this is test web</h1>" > /opt/compose_nginx/wwwroot/index.html
[root@localhost nginx]# vim /opt/compose_nginx/docker-compose.yml 
version: '3'

services:
  nginx:
    container_name: web1
    hostname: nginx
    build:
      context: ./nginx
      dockerfile: Dockerfile
    ports:
      - 1216:80
      - 1217:443
    networks:
      lnmp:
        ipv4_address: 172.18.0.10
    volumes:
      - ./wwwroot:/usr/local/nginx/html

networks:
  lnmp:
    driver: bridge
    ipam:
      config:
      - subnet: 172.18.0.0/16

[root@localhost nginx]# cd /opt/compose_nginx/
[root@localhost compose_nginx]# docker-compose -f docker-compose.yml up -d
..........   #最后显示为类似以下内容为成功
Creating web1 ... done      #意思:正在创建 web1 ... 已完成




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



[root@localhost compose_nginx]# docker ps -a
CONTAINER ID   IMAGE                 COMMAND                   CREATED          STATUS                     PORTS                                       NAMES
4ba5b7c7f5c2   compose_nginx_nginx   "/run.sh"                 52 minutes ago   Exited (0) 2 minutes ago                                               web1
3a284c552f59   registry:latest       "/entrypoint.sh /etc…"   7 hours ago      Up 7 hours                 0.0.0.0:5000->5000/tcp, :::5000->5000/tcp   registry

#必须在 docker-compose.yml所在目录执行此命令
[root@localhost compose_nginx]# docker-compose ps
Name   Command   State    Ports
-------------------------------
web1   /run.sh   Exit 0        

#下载相关应用,并查看实验所有配置
[root@localhost compose_nginx]# yum install -y tree
[root@localhost compose_nginx]# tree /opt/compose_nginx/
/opt/compose_nginx/
├── docker-compose.yml             #创建模板脚本
├── nginx
│   ├── Dockerfile                 #创建容器脚本
│   ├── nginx-1.24.0.tar.gz        #复制源码包
│   └── run.sh                     #启动服务脚本
└── wwwroot
    └── index.html                 #站点网页

2 directories, 5 files

  • 15
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`docker-compose`是一个用于管理应用及其依赖环境的强大工具。它允许开发者通过单个YAML文件配置应用程序的所有服务、网络和卷,并使用一个命令启动整个应用环境。以下是关于`docker-compose`的一些基本概述: ### `docker-compose`的主要用途 1. **简化部署**:通过将所有服务、依赖项和配置信息组织在一个地方,`docker-compose`使得应用的部署过程变得简单而统一。 2. **跨平台一致性**:无论您是在本地开发环境中还是在生产服务器上运行应用,`docker-compose`都能提供一致的体验。 3. **便于维护**:对于有多个微服务的应用程序,`docker-compose`帮助保持各个组件之间的相互依赖性和配置的一致性。 4. **快速迭代**:支持快速测试和修改服务配置,无需每次都重启容器。 5. **集成自动化**:可以轻松地将构建、测试、部署等步骤整合到CI/CD流程中。 ### 使用示例 假设有一个简单的Web应用,包含前端(React)和服务端(Node.js)。我们可以创建两个Dockerfile分别构建这两个服务,并编写一个`docker-compose.yml`文件来定义它们以及它们之间的连接。 ```yaml version: '3' services: web: build: . ports: - "8080:80" depends_on: - db db: image: postgres:latest ``` 在这个例子中,我们定义了两个服务:web和服务端数据库。`web`服务使用当前目录下的Dockerfile进行构建,并将其暴露在外部主机的8080端口上。同时,它依赖于名为`db`的服务。这意味着在启动web服务之前,数据库服务会先启动并准备就绪。 ### 安装和运行 通常,您需要安装`docker`和`docker-compose`。然后,只需在包含`docker-compose.yml`文件的项目根目录下执行以下命令即可启动应用: ``` docker-compose up ``` 这个命令将会根据`docker-compose.yml`文件的内容启动所有指定的服务,并自动处理依赖关系。当所有的服务都已准备好时,终端将显示一条确认消息。 ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值