Docker-Compose容器集群编排管理
1.Docker-Compose概述
Docker-Compose将所管理的容器分为三层,分别是项目(project)、服务(service)以及容器(container) 。
Docker-Compose运行目录下的所有文件组成一个项目,若无特殊指定项目名即为当前目录名。
一个工程当中可包含多个服务,每个服务都包含一个名称、镜像、端口映射、环境变量、挂载点等信息。
Docker-Compose的项目配置文件默认为docker-compose.yml,可通过环境变量COMPOSE_FILE或-f参数自定义配置文件,其定义了多个有依赖关系的服务及每个服务运行的容器。
Compose允许用户通过一个单独的docker-compose.yml模板文件(AM格式),来定义一组相关联的应用容器为一个项目(project)。
2. YAML 文件格式及编写注意事项
YAML 是一种标记语言,它可以很直观的展示数据序列化格式,可读性高。类似于 json 数据描述语言,语法比 json 简单的很多。YAML 数据结构通过缩进来表示,连续的项目通过减号来表示,键值对用冒号分隔,数组用中括号 [] 括起来, hash 用花括号 {} 括起来。
使用 YAML 时需要注意下面事项:
●大小写敏感
●通过缩进表示层级关系
●不支持制表符 tab 键缩进,只能使用空格缩进
●缩进的空格数目不重要,只要相同层级左对齐,通常开头缩进2个空格
●用 # 号注释
●符号字符后缩进1个空格,如冒号 : 、逗号 , 、横杠 -
●如果包含特殊字符用单引号('')引起来会作为普通字符串处理,双引号(""): 特殊字符作为本身想表示的意思
3. 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,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
4. Docker-compose常用命令
5 使用Docker-compose创建LNMP环境
1安装docker-compose
###将docker-compose安装包上传到/opt路径
cd /opt
rz -E
#docker-compose
mv ./docker-compose /usr/local/bin/
#修改docker-compose在系统环境变量中的执行权限
chmod +x /usr/local/bin/docker-compose
#查看版本
docker-compose --version
2 创建工作目录,删除多余镜像与容器
mkdir -p /opt/compose/compose-lnmp
cd /opt/compose/compose-lnmp
cp -r /opt/lnmp/nginx /opt/lnmp/php /opt/lnmp/mysql ./ #此处/opt/lnmp/目录下的nginx、mysql和php,是上一篇博客中成功安装lnmp各自组件
docker rm -f $(docker ps -aq) #删除系统中目前所有的容器
docker images
docker rmi 镜像名:标签 #删除多余无用的镜像,切记需要保留创建lnmp中用到的镜像
docker network list
docker network rm 自定义网络名 #此处删除之前自定义的网路,防止再次运行docker-compose,发生冲突
3 制作docker-compose的 .yml文件
vim /opt/compose/compose-lnmp/docker-compose.yml
version: '3'
services:
nginx:
build:
context: ./nginx
dockerfile: Dockerfile
container_name: nginx
ports:
- 80:80
volumes:
- ./nginx/html:/usr/local/nginx/html
networks:
lnmp:
ipv4_address: 172.18.0.10
mysql:
#build:
# context: ./mysql
# dockerfile: Dockerfile
image: mysql:centos7
container_name: mysql
ports:
- 3306:3306
volumes:
- db-data:/usr/local/mysql
networks:
lnmp:
ipv4_address: 172.18.0.20
privileged: true
php:
#build:
# context: ./php
# dockerfile: Dockerfile
image: php:clr
container_name: php
ports:
- 9000:9000
volumes:
- db-data:/usr/local/mysql
- ./nginx/html:/usr/local/nginx/html
networks:
lnmp:
ipv4_address: 172.18.0.30
depends_on:
- nginx
- mysql
networks:
lnmp:
driver: bridge
ipam:
config:
- subnet: 172.18.0.0/16
volumes:
db-data:
4 使用指定的docker-compose模版文件,启动容器
docker-compose -f docker-compose.yml up -d
docker-compose ps
nginx创建Dockerfile
vim /opt/lnmp/nginx/Dockerfile
FROM centos:7
MAINTAINER this is nginx image <zf 2024-07-15>
ADD nginx-1.22.0.tar.gz /usr/local/
RUN yum install -y pcre-devel zlib-devel openssl-devel gcc gcc-c++ make && \
useradd -M -s /sbin/nologin nginx && \
cd /usr/local/nginx-1.22.0 && \
./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module && make -j2 && make install
#COPY nginx.conf /usr/local/nginx/conf/nginx.conf
EXPOSE 80
#EXPOSE 443
CMD ["/usr/local/nginx/sbin/nginx","-g","daemon off;"]
docker build -t nginx:centos7 . #在当前目录中,创建nginx:centos7镜像
原文地址:https://blog.csdn.net/2401_83786744/article/details/140520711
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!