首页 > 系统相关 >【Docker】Supervisor 实现单容器运行多服务进程

【Docker】Supervisor 实现单容器运行多服务进程

时间:2025-01-16 12:32:11浏览次数:3  
标签:容器 Supervisor supervisord supervisorctl 指定 进程 Docker 日志

本文内容均来自个人笔记并重新梳理,如有错误欢迎指正!

如果对您有帮助,烦请点赞、关注、转发、订阅专栏!


专栏订阅入口

| 精选文章 | Kubernetes | Docker | Linux | 羊毛资源 | 工具推荐 |


往期精彩文章

【Docker】(全网首发)Kylin V10 下 MySQL 容器内存占用异常的解决方法

【Docker】(全网首发)Kylin V10 下 MySQL 容器内存占用异常的解决方法(续)

【K8s】专题十五(6):Kubernetes 网络之 Pod 网络调试


目录

一、背景介绍

二、Supervisor 介绍

1、基本概念

2、主要作用

3、工作原理

三、Supervisor 使用

1、生成 Dockerfile 文件

2、生成 supervisord.conf 文件

3、构建镜像

三、Supervisorctl 常用命令


一、背景介绍

近期笔者在工作中遇到一个特殊的需求场景,即在单个容器中同时运行 php-fpm 和 nginx 服务,并通过 cron 服务管理计划任务。

由于使用 systemctl 工具管理进程相对复杂,笔者最终选用 Supervisor 工具来实现上述需求。本文将对 Supervisor 的相关知识、使用方法等进行详细介绍。


二、Supervisor 介绍
1、基本概念

Supervisor 是一个基于 Python 开发的进程管理工具,主要用于监控、控制 Linux 操作系统上的多个进程,通过将命令行进程转变为后台守护进程,并提供监控和自动重启功能,以确保服务的高可用性。

Supervisor 采用 C/S(客户端/服务端)架构来实现进程管理:

  • 服务端:即主进程 supervisord
    • supervisord 启动时会生成配置文件中定义的子进程,并监控子进程的状态,当子进程崩溃时对其进行自动重启
  • 客户端:即命令行工具 supervisorctl
    • supervisorctl 通过 Unix 域套接字或 TCP 套接字与服务端进行通信,允许用户与 supervisord 主进程进行交互,对子进程执行启动、停止、重启、查看状态等操作

2、主要作用
  • 管理进程:Supervisor 可以启动、停止、重启和监控多个进程,确保进程异常退出后能够自动重启
  • 记录日志:Supervisor 可以记录子进程的标准输出和错误输出,方便用户进行监控、调试、排查问题等
  • 灵活配置:Supervisor 可以指定配置文件内容,方便用户灵活地配置需要管理的进程及其属性。默认配置文件为 /etc/supervisor/supervisord.conf
  • 集中管理:Supervisor 可以对多个进程、进程组进行集中管理,方便用户操作

3、工作原理
  • Supervisord 作为主进程启动,并置于守护进程模式
  • Supervisord 根据配置文件中的设置,逐一启动子进程
  • Supervisord 通过操作系统信号机制,实时监控子进程的运行状态
  • Supervisord 在子进程状态异常时接收到控制信号,按照配置文件中的设置对子进程进行重启等操作


三、Supervisor 使用

以背景介绍中的需求场景为例,使用已安装 fpm 的 php 官方镜像作为基础进行 Docker 镜像构建,安装 supervisor、nginx、cron 服务,并自定义 Supervisor 配置文件 supervisord.conf。

1、生成 Dockerfile 文件
cat > Dockerfile << EOF
FROM php:7.4.33-fpm

RUN sed -i 's#deb.debian.org#mirrors.aliyun.com#g' /etc/apt/sources.list
RUN apt-get update && \
    apt-get install -y supervisor nginx cron \
    && rm -rf /var/lib/apt/lists/* \
    && mkdir -p /etc/supervisor/conf.d/
COPY supervisord.conf /etc/supervisor/conf.d/
CMD ["/usr/bin/supervisord", "-c", "/etc/supervisor/supervisord.conf"]

EOF

2、生成 supervisord.conf 文件
cat > supervisord.conf <<EOF
[supervisord]                            # 定义主进程
nodaemon=true                              # Supervisor 默认处于守护进程模式,而在容器中则需要处于前台运行以保持容器活跃

[program:php-fpm]                        # 定义子进程
command=bash -c "sleep 1 && php-fpm"
process_name=%(program_name)s
user=root
autostart=true
autorestart=true
startretries=5
exitcodes=0,2,70
stopsignal=QUIT
stopwaitsecs=2
stdout_logfile=/var/log/supervisor/php-fpm.log

[program:nginx]
command=bash -c "sleep 1 && /usr/sbin/nginx -g 'daemon off;'"
process_name=%(program_name)s
user=root
autostart=true
autorestart=true
startretries=5
exitcodes=0,2,70
stopsignal=INT
stopwaitsecs=2
stdout_logfile=/var/log/supervisor/nginx.log

[program:cron]
command=bash -c "sleep 1 && /usr/sbin/cron -f"       # cron 需要添加 -f 参数确保处于前台运行
process_name=%(program_name)s
user=root
autostart=true
autorestart=true
startretries=5
exitcodes=0,2,70
stopsignal=QUIT
stopwaitsecs=2
stdout_logfile=/var/log/supervisor/cron.log

EOF

部分可配置参数说明如下:

## 全局配置
[unix_http_server]
# file:指定 UNIX 域套接字的位置,供 supervisorctl 和 supervisord 进行通信,例如:
file=/opt/super/supervisor.sock
---------------------------------------------------------------------------------
[inet_http_server]
# port:指定 Web 界面 TCP 监听的 IP 和端口,例如:
port=127.0.0.1:9001
---------------------------------------------------------------------------------
[supervisord]  
# logfile:supervisord 日志文件路径,默认值为 $CWD/supervisord.log
# logfile_maxbytes:supervisord 日志文件的最大字节数,超过后会创建新文件,设置为 0 表示不限制
# logfile_backups:保留的日志文件备份数量
# loglevel:日志记录等级,默认为 INFO
# pidfile:supervisord PID 文件路径,默认值为 $CWD/supervisord.pid
# nodaemon:默认为 false,以守护进程模式运行;如果设置为 true,则以前台模式运行
-----------------------------------------------------------------------------------------------------
## 进程管理
[program:test-server]
# command:进程启动命令
# process_name:进程名称
# user:进程启动用户
# directory:启动命令执行前切换到的目录
# autostart:是否随 supervisord 启动而自动启动该进程,默认为 true
# autorestart:是否在进程退出时自动重启,默认为 true
# startretries:启动失败时重试次数上限
# stopsignal:停止进程时发送的信号,例如 INT、QUIT
# stdout_logfile:指定标准输出的日志文件路径,可以是 /dev/stdout
# stderr_logfile:指定标准错误的日志文件路径,可以是 /dev/stderr
-----------------------------------------------------------------------------------------------------
## 配置包含
[include]
files=/etc/supervisor/conf.d/*.ini

3、构建镜像
docker build -t php:7.4.33-fpm-nginx -f Dockerfile . --no-cache


三、Supervisorctl 常用命令
# 查看进程状态(所有)
supervisorctl status all

# 查看进程状态(指定)
supervisorctl status <process_name>

# 启动进程(所有)
supervisorctl start all

# 启动进程(指定)
supervisorctl start <process_name>

# 停止进程(所有)
supervisorctl stop all

# 停止进程(指定)
supervisorctl stop <process_name>

# 重启进程(所有)
supervisorctl restart all

# 重启进程(指定)
supervisorctl restart <process_name>

# 更新配置(所有)
supervisorctl update all

# 更新配置(指定)
supervisorctl update <process_name>

# 清空进程日志(所有)
supervisorctl clear all

# 清空进程日志(指定)
supervisorctl clear <process_name>

# 查看帮助
supervisorctl -h

标签:容器,Supervisor,supervisord,supervisorctl,指定,进程,Docker,日志
From: https://blog.csdn.net/2401_82795112/article/details/145163984

相关文章

  • docker 入门到实战
    一、Docker能解决什么问题?Docker作为一种容器化技术,能够解决多种软件开发和运维中的问题,主要包括:1.环境一致性:确保开发、测试和生产环境的一致性,避免“在我机器上可以运行”的问题。2.依赖管理:容器封装了应用及其所有依赖,使得应用可以在任何支持Docker的环境中运行,无需担......
  • docker-compose的使用
    docker-compose的使用一、简介二、安装与卸载linuxmacos、window卸载测试安装成功三、dockercompose使用四、Compose模版文件五、Compose应用一、简介Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。其代码目前在https://github.c......
  • Debian 安装 Docker
    卸载已有Docker如果你之前安装过DockerEngine之前,你需要卸载旧版本,避免冲突:forpkgindocker.iodocker-docdocker-composepodman-dockercontainerdrunc;dosudoapt-getremove$pkg;done安装方法使用官方安装脚本自动安装(推荐使用)下载官方脚本curl-fsSL......
  • 告别付费拍证件照!NAS 基于Docker部署免费证件照生成工具
    你在生活中有没有遇到过急需证件照的场景?在某些考试前发现证件照还没准备好;求职面试时,也需要附上职业证件照,生活中还有很多需要证件照的场景。本文章利用NAS基于Docker部署一款证件照自动生成的工具—HivisionIDPhotos。利用‌HivisionIDPhotos‌,通过一张生活照片,即可生成一张证......
  • Docker实战案例:构建并部署一个Node.js Web应用
    在当今快速迭代的软件开发环境中,容器化技术以其轻量级、可移植性和高效资源利用等特性,成为了开发和运维团队不可或缺的工具。Docker作为容器技术的佼佼者,极大地简化了应用的打包、分发和部署流程。本文将通过一个完整的Node.jsWeb应用案例,展示如何使用Docker从代码编写到部......
  • 本地打包docker images并上传到服务器.250115
    情景:服务器dockerPull拉不下来dockerpulleaszlab/kubeasz-k8s-bin:v1.31.2Get"https://registry-1.docker.io/v2/":net/http:requestcanceledwhilewaitingforconnection(Client.Timeoutexceededwhileawaitingheaders)2025-01-1417:06:35[ezdown:767]......
  • docker部署d2l环境
    编写dockerfile#使用NVIDIA提供的CUDA基础镜像,包含CUDA11.8.0和cuDNN8,基于Ubuntu22.04FROMnvidia/cuda:11.8.0-cudnn8-devel-ubuntu22.04#设置维护者信息MAINTAINERwatcherprime<woma@126.com>#设置环境变量,包括时区、非交互式前端和PATH变量ENVTZ=Asia/Shanghai......
  • docker-compose自动部署go项目全流程,本地到镜像仓库到服务器,踩坑笔记
    声明:个人所学记录,有可以改进的地方希望不吝指教Dockerfile#使用golang官方镜像作为构建环境FROMgolang:1.23-alpineASbuilder#设置工作目录WORKDIR/app#设置环境变量镜像变量ENVGO111MODULE=onENVGOPROXY=https://goproxy.cn,direct#复制go.mod和go.sum文......
  • DOMjudge8.2.3配置DOMserver(基于Docker一键配置,全网最详细,看完包会配)
    文章目录前言配置方式1:手动配置nginx+php-fpm配置方式2:Docker一键安装1.部署MariaDB数据库2.部署DOMserver3.获取初始admin密码以及judgehost密码4.修改grub5.测试6.修改配置文件6.0前言(修改配置必看)6.1[configchecker]-MySQLsettings修改常见问题及对应解决......
  • FastGPT及大模型API(Docker)私有化部署指南
    FastGPT及大模型API(Docker)私有化部署指南​​经过优化,在不影响FastGPT功能的情况下,大幅降低了部署的设备配置要求,仅需1c1h即可正常部署使用。官方要求配置:​​优化后的实际占用情况:运行内存仅需370M(测试学习场景下)​​官方推荐部署容器:​pg​......