Docker 最佳实战:定制 Docker compose 通用模板
2024 年云原生运维实战文档 99 篇原创计划 第 003 篇 |Docker 最佳实战「2024」系列 第 003 篇
前言
你好,欢迎来到运维有术。
今天分享的内容是 Docker 最佳实战「2024」 系列文档中的 定制 Docker compose 通用模板。
内容导图
实战服务器配置 (架构 1:1 复刻小规模生产环境,配置略有不同)
主机名 | IP | CPU(核) | 内存(GB) | 系统盘(GB) | 数据盘(GB) | 用途 |
---|---|---|---|---|---|---|
docker-node-1 | 192.168.9.81 | 4 | 16 | 40 | 100 | Docker 节点 1 |
docker-node-2 | 192.168.9.82 | 4 | 16 | 40 | 100 | Docker 节点 2 |
docker-node-3 | 192.168.9.83 | 4 | 16 | 40 | 100 | Docker 节点 3 |
合计 | 3 | 12 | 48 | 120 | 300 |
实战环境涉及软件版本信息
- 操作系统:openEuler 22.03 LTS SP3
- Docker:24.0.7
- Containerd:1.6.27
1. 为什么要做模板?
Docker 容器的创建启动方式有两种:
- 通过 docker run 直接运行
- 编写 docker-compose.yml 文件,通过
docker-compose
或是docker compose
命令运行
说明: docker compose 的方式只有使用 Docker 官方提供的软件源安装 Docker 引擎并且安装了
docker-compose-plugin
才支持
我们分享的内容都是基于 docker-compose.yml
创建并管理容器,为了提高工作效率,有必要定义一套标准的初始化模板。
2. 规划创建标准化模板
本文以 Nginx 服务为例,创建标准化的 docker-compose.yml
文件通用模板。
2.1 创建容器存储根目录
本文使用 /data/containers
目录作为所有容器的根目录。
mkdir /data/containers
2.2 创建容器常用目录
以 Nginx 为例,创建 Nginx 容器数据的常用基本目录,实际使用中可根据需求调整。
代码语言:bash复制mkdir -p /data/containers/nginx/{data,config,templates,logs}
- data 目录:建议, 存储容器持久化数据
- config 目录:建议, 存储容器使用的配置文件
- logs 目录:建议, 存储容器的持久化日志
- templates 目录:可选, 属于 Nginx 服务专属 ,用于存放配置文件模板
2.3 创建 docker-compose 文件模板
最小化的标准配置模板 docker-compose.yml
。
version: '3.5'
services:
nginx:
container_name: nginx
image: nginx:1.25.4
environment:
- NGINX_HOST=foobar.com
- NGINX_PORT=80
volumes:
- ${DOCKER_VOLUME_DIRECTORY:-.}/data:/usr/share/nginx/html
- ${DOCKER_VOLUME_DIRECTORY:-.}/config/nginx.conf:/etc/nginx/nginx.conf
- ${DOCKER_VOLUME_DIRECTORY:-.}/templates:/etc/nginx/templates
ports:
- "80:80"
networks:
default:
name: nginx
重点说明: 一个最小化的模板包含以下基本内容,其他服务按模板修改套用即可。
- services.nginx:服务名称,用于 docker-compose 管理控制,一个 docker-compose.yml 中可以配置多个服务
- services.nginx.container_name:nginx 服务对应的容器名称
- services.nginx.image: ngin x 服务对应的容器使用的镜像,建议带上特定的 tag,不建议使用 latest
- services.nginx.environment:nginx 服务对应的容器运行时使用的环境变量
- services.nginx.volumes:nginx 服务对应的容器运行时挂载的目录或文件,本文使用了 shell 默认变量,定义了一个变量 DOCKER_VOLUME_DIRECTORY 并设置该变量的默认值为当前目录
- services.nginx.ports:nginx 服务对应的容器运行时需要暴露的端口
- networks:所有服务容器运行时创建的网络名称,同一个 docker-compose.yml 配置文件定义的服务可以使用相同的 networks
2.4 创建并启动服务
启动 Docker 服务,并设置开机自启。
代码语言:bash复制cd /data/containers/nginx
# 下载 docker-compose 二进制的方式,使用下面的命令
# docker-compose up -d
# Docker 官方 RPM 包安装的 Docker,使用下面的命令
docker compose up -d
2.5 验证服务
- 查看 Docker 信息
cd /data/containers/nginx
docker compose ps -a
3. 自动化 Shell 脚本
全文所有的操作,我都整理成了自动化脚本:
- 自动化脚本
deploy-nginx.sh
#!/bin/bash
set -e
mkdir -p /data/containers/nginx/{data,config,templates,logs}
cd /data/containers/nginx
cat > docker-compose.yml << "EOF"
version: '3.5'
services:
nginx:
container_name: nginx
image: nginx:1.25.4-alpine
environment:
- NGINX_HOST=foobar.com
- NGINX_PORT=80
volumes:
- ${DOCKER_VOLUME_DIRECTORY:-.}/data:/usr/share/nginx/html
#- ${DOCKER_VOLUME_DIRECTORY:-.}/config/nginx.conf:/etc/nginx/nginx.conf
- ${DOCKER_VOLUME_DIRECTORY:-.}/templates:/etc/nginx/templates
ports:
- "80:80"
networks:
default:
name: nginx
EOF
docker compose up -d
docker compose ps
注意: 自动化脚本中 volumes 小节注释了一段内容,实际使用中可以提前准备好该文件,并取消注释。
4. 课后作业
根据本文所学,请完成以下实战任务。
- 定制一套适合自己的 docker-compose.yml 自动初始化模板
- 使用模板部署 Nginx 服务
5. 总结
本文分享了定制最小化 docker-compose.yml 文件标准模板的详细流程及注意事项。主要内容概括如下:
- docker-compose.yml 模板的定制
- 利用模板创建 Nginx 服务
- 编写 docker-compose.yml 模板自动化部署服务的脚本
Get 本文实战视频(请注意,文档视频异步发行,请先关注)
- B 站 运维有术
免责声明:
- 笔者水平有限,尽管经过多次验证和检查,尽力确保内容的准确性,但仍可能存在疏漏之处。敬请业界专家大佬不吝指教。
- 本文所述内容仅通过实战环境验证测试,读者可学习、借鉴,但严禁直接用于生产环境。由此引发的任何问题,作者概不负责!
结束语
如果你喜欢本文,请分享、收藏、点赞、评论! 请持续关注 @ 运维有术,及时收看更多好文!
欢迎加入 「运维有术·云原生实战训练营」 ,获取更多的 KubeSphere、Kubernetes、云原生运维实战技能。
版权声明
- 所有内容均属于原创,感谢阅读、收藏,转载请联系授权,未经授权不得转载。