supervisor系列:4、子进程

2023-11-15

supervisor系列:4、子进程


supervisord的主要目的是根据配置文件中的数据创建和管理进程。它通过创建子进程来实现这一点。supervisor生成的每个子进程在其整个生命周期内都由supervisord管理( supervisord是它创建的每个进程的父进程)。当子进程死亡时,通过 SIGCHLD信号通知supervisor其子进程死亡,并执行适当的操作。

1. 非后台运行的子进程

应该在supervisor下运行的程序不应该将自己守护化。相反,它们应该在前台运行。它们不应该与启动它们的终端分离。

判断一个程序是否将在前台运行的最简单方法是运行从shell提示符调用该程序的命令。如果它给了你对终端的控制权,但是继续运行,那么它本身就会被daemon化,这几乎肯定是在supervisor下运行的错误方式。您需要运行一个命令,该命令实际上需要按Ctrl-C以恢复对终端的控制。如果在运行它之后,不需要按Ctrl-C就返回一个shell提示,那么在supervisor下它是没有用的。所有程序都有在前台运行的选项,但没有标准的方式来做它;您需要阅读每个程序的文档。

下面是一些配置文件示例,它们可以在Supervisor下的“前台”模式下启动通用程序。

1.1 程序配置示例

下面是一些“真实世界”的程序配置示例:

1.1.1 Apache 2.2.6

[program:apache2]
command=/path/to/httpd -c "ErrorLog /dev/stdout" -DFOREGROUND
redirect_stderr=true

1.1.2 Two Zope 2.X instances and one ZEO server

[program:zeo]
command=/path/to/runzeo
priority=1

[program:zope1]
command=/path/to/instance/home/bin/runzope
priority=2
redirect_stderr=true

[program:zope2]
command=/path/to/another/instance/home/bin/runzope
priority=2
redirect_stderr=true

1.1.3 Postgres 8.X

[program:postgres]
command=/path/to/postmaster
; we use the "fast" shutdown signal SIGINT
stopsignal=INT
redirect_stderr=true

1.1.4 OpenLDAP slapd

[program:slapd]
command=/path/to/slapd -f /path/to/slapd.conf -h ldap://0.0.0.0:8888
redirect_stderr=true

1.2 其它示例

其他shell脚本的例子可以在http://thedjbway.b0llix.net/services.html上找到,这些脚本可以用来在supervisord下启动服务。这些例子实际上是针对daemontools的,但前提对于supervisor是一样的。

另一个用于在前台启动各种程序的方法集合可以从http://smarden.org/runit/runscripts.html获得。

2. pidproxy程序

有些进程(如mysqld)会忽略由supervisord生成的发送给实际进程的信号。相反,由这些类型的程序创建的“特殊”线程/进程负责处理信号。这是有问题的,因为supervised只能杀死它自己创建的进程。如果一个由supervised创建的进程创建了它自己的子进程,那么supervised就不能杀死它们。

幸运的是,这些类型的程序通常会编写一个“pidfile”,其中包含“特殊”进程的PID,并用于读取和杀死进程。作为这种情况的解决方案,一个特殊的pidproxy程序可以处理这类进程的启动。pidproxy程序是一个启动进程的小垫片,在接收到信号后,将信号发送给pidfile中提供的pid。下面提供了一个启用pidproxy程序的示例配置程序条目。

[program:mysql]
command=/path/to/pidproxy /path/to/pidfile /path/to/mysqld_safe

当supervisor被安装时,pidproxy程序被放到你的配置的$BINDIR中(它是一个“控制台脚本”)。

3. 子进程环境

子进程将继承用于启动supervisord的shell环境。在子环境中,有几个环境变量也会被supervisord自己设置,包括SUPERVISOR_ENABLED(一个指示进程处于supervisor控制下的标志),SUPERVISOR_PROCESS_NAME(这个进程的配置文件指定的进程名)和SUPERVISOR_GROUP_NAME(子进程的配置文件指定的进程组名)。

这些环境变量可以在名为environment(适用于所有子进程)的[supervisor]节配置选项中覆盖,或者在per- [program:x]environment配置选项中覆盖(仅适用于[program:x]节指定的子进程)。这些“环境”设置是附加的。换句话说,每个子进程的环境将包括:

在shell中设置的环境变量用于启动supervisor…

… 添加到/覆盖 …

… 在“environment”全局配置选项中设置的环境变量 …

… 添加到/覆盖 …

​… supervisor-specific环境变量(SUPERVISOR_PROCESS_NAME SUPERVISOR_ENABLED SUPERVISOR_GROUP_NAME) …

​… 添加到/覆盖 …

​… 在每个进程中设置的环境变量“环境”配置选项。

在运行子进程时,没有shell被supervisord执行,所以像USERPATHHOMESHELLLOGNAME等环境变量不会从默认值改变或重新分配。注意,当您以root用户运行配置中带有user=节的supervisord程序时,这一点特别重要。与cron不同,当对user=程序配置选项中定义的用户执行setuid时,supervisord不会试图识别和覆盖基本环境变量,如USERPATHHOMELOGNAME。如果需要为特定程序设置环境变量,而这些变量可能由shell调用为特定用户设置,则必须在environment= 程序配置选项中显式设置。下面是设置这些环境变量的示例。

[program:apache2]
command=/home/chrism/bin/httpd -c "ErrorLog /dev/stdout" -DFOREGROUND
user=chrism
environment=HOME="/home/chrism",USER="chrism"

4. 进程状态

一个由supervisord控制的过程在任何时候都将处于以下状态之一。您可以在客户机的各种用户界面元素中看到这些状态名。

STOPPED (0)

由于停止请求,进程已经停止或从未启动。

STARTING (10)

由于启动请求,进程正在启动。

RUNNING (20)

进程正在运行。

BACKOFF (30)

进程进入STARTING状态,但随后退出的速度太快(在startsecs中定义的时间之前),无法移动到RUNNING状态。

STOPPING (40)

由于停止请求,进程正在停止。

EXITED (100)

进程从RUNNING状态退出(预期或意外)。

FATAL (200)

进程无法成功启动。

UNKNOWN (1000)

进程处于未知状态(supervisord程序错误)。

每一个在supervisor下运行的进程都按照下面的有向图通过这些状态进行。

Subprocess State Transition Graph

子进程状态转换图

如果进程已从管理上停止或从未启动过,则该进程处于STOPPED状态。

当一个自动重启的进程处于BACKOFF状态时,它将被supervisord自动重启。它将在STARTINGBACKOFF状态之间切换,直到明显地发现它无法启动,因为startretries的数量已经超过了最大数量,这时它将过渡到FATAL状态。

注意:

根据后续尝试次数的不同,重试将花费越来越多的时间,每次增加一秒。

因此,如果您设置startretries=3,supervisord将在每次重启尝试之间等待1秒、2秒、3秒,总共等待5秒。

当一个进程处于EXITED状态时,它会自动重启:

  • 如果它的autorestart参数设置为false,则永远不会。
  • 如果它的autorestart参数设置为true,则无条件。
  • 如果其autorestart参数设置为unexpected,则有条件地设置。如果它退出时的退出码与进程的exitcodes配置参数中定义的退出码不匹配,它将被重新启动。

如果将流程配置为有条件或无条件地自动重启,流程将自动从EXITED过渡到RUNNINGRUNNINGEXITED之间的转换数量没有任何限制:可以创建一个不断重启退出进程的配置。这是一个特性,而不是一个bug。

如果最终处于FATAL状态(必须从这种状态手动重新启动),则自动重新启动的进程将永远不会被自动重新启动。

进程通过一个管理停止请求转换到STOPPING状态,然后将以STOPPED状态结束。

无法成功停止的进程将永远处于STOPPING状态。在正常操作期间不应该出现这种情况,因为这意味着进程没有响应上级发送给它的最终SIGKILL信号,这在UNIX下是“不可能的”。

状态转换总是需要用户操作来调用:

FATAL` -> `STARTING
RUNNING` -> `STOPPING

状态转换通常(但不总是)需要用户操作来调用,例外情况请注意:

STOPPED -> STARTING (如果进程被配置为自动启动,则在supervisord启动时除外)

EXITED -> STARTING (除非进程被配置为自动重启)

所有其他状态转换都由supervise自动管理。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

supervisor系列:4、子进程 的相关文章

  • 使用Supervisor和NGINX部署

    目录 SupervisorNGINX Supervisor span class token function sudo span span class token function apt get span y update span c
  • Supervisor 使用说明,轻松管理进程

    Supervisor 使用说明 xff0c 轻松管理进程 导读 要想在终端后台常驻进程 xff0c 首先想到的是在命令后加 amp 符号 xff0c 来达到隐藏程序在后台的目的 xff0c 尽管看起来进程已经在后台运行了 xff0c 实际上
  • 进程管理

    彩蛋 操作系统总目录 戳我 进程 进程的概念 进程的定义 程序 就是一个指令序列 程序段 数据段 PCB三部分组成了进程实体 进程映像 一般情况下 xff0c 我们把进程实体就简称为进程 例如 xff0c 所谓创建进程 xff0c 实质上是
  • Redhat进程管理

    进程管理 概论 xff1a 程序 xff1a 静态的代码 xff0c 占用磁盘空间 进程 xff1a 动态的代码 xff0c 占用内存 cpu xff08 提供服务的主体 xff09 进程的唯一标识 xff1a PID 编号 父进程 子进程
  • supervisor搭建与配置

    supervisor 是管理程序进程启动和状态 xff0c 当程序进程死掉 xff0c supervisor会把这个程序进程重新拉起 python版本最低要2 7 pip install supervisor 就可以安装了 如果是pytho
  • Linux进程管理(一) Linux进程的基本概念

    Linux进程的基本概念 最后更新时间2020 04 09 Ubuntu linux的所有任务都是在操作系统内核的调度下由CPU执行 xff0c 很多时候 xff0c Linux是将任务和进程的概念合在一起 进程的标准定义 xff1a 进程
  • linux系统--进程管理&计划任务

    kill 9 PID 强制关闭PID kill 1 PID 重启PID的进程 pgrep ssh 查询ssh所有的PID pkill ssh 关闭ssh服务 不需要查询ssh进程的PID 进程优先级 nice指定程序的运行和优先级 n的取值
  • Linux内核:进程管理——进程文件系统 /proc详解

    proc详解 xff1a 内容摘要 xff1a Linux系统上的 proc目录是一种文件系统 xff0c 即proc文件系统 Linux系统上的 proc目录是一种文件系统 xff0c 即proc文件系统 与其它常见的文件系统不同的是 x
  • Linux配置Supervisor 配置遇到的坑

    在linux中web 应用部署到线上后之后发现退出终端后网站就无法访问了 所以需要用Supervisor来守护进程 xff0c 它可以保证应用一直处于运行状态 xff0c 在遇到程序异常 报错等情况 xff0c 导致 web 应用终止时 x
  • supervisor系列:2、运行supervisor

    supervisor系列 2 运行supervisor 文章目录 supervisor系列 2 运行supervisor 1 添加一个程序 2 运行supervisord 2 1 supervisord命令行配置 3 运行superviso
  • 操作系统引论和进程管理部分习题

    一 单选题 1 操作系统是一种 A 通用软件 B 系统软件 C 应用软件 D 软件包 正确答案 B 2 操作系统的 管理部分负责对进程进行调度 A 主存储器 B 控制器 C 运算器 D 处理机 正确答案 D 3 若把操作系统看作计算机系统资
  • centos 普通用户操作 supervisor 报错

    当我们在centos系统中使用普通用户操作supervisor时 可能会有以下权限问题 error
  • 使用supervisor使Laravel的queue保持后台常驻

    我的个人博客 逐步前行STEP 一 安装supervisor 1 yum install python setuptools 2 easy install supervisor 二 配置supervisor 1 echo superviso
  • 趣谈操作系统原理,存储管理之页式、段式、段页式存储

    一 概述 非连续分配管理方式允许一个程序分散地装入到不相邻的内存分区 根据分区的大小是否固定分为分页式存储管理方式和分段式存储管理方式 分页存储管理方式中 又根据运行作业时是否要把作业的所有页面都装入内存才能运行分为基本分页式存储管理方式和
  • centos7安装配置supervisor保姆教程

    介绍 Supervisor是一个进程管理工具 是由python语言编写 基于linux操作系统的一款服务器管理工具 用以监控服务器的运行 发现问题能立即自动预警及自动重启等功能 是一个客户 服务器系统 服务器端称为supervisord 管
  • 进程管理(十三)---进程调度基本原理

    1 为什么需要调度 进程调度的概念比较简单 我们假设在一个单核处理器的系统中 同一时刻只有一个进程可以拥有处理器资源 那么其他的进程只能在就绪队列中等待 等到处理器空闲之后才有计划获得处理器资源来运行 在这种场景下 操作系统就需要从众多的就
  • Linux的进程管理

    目录 1 概述 2 进程描述符 2 1 进程描述符的分配 2 2 进程描述符的存放 2 3 进程状态 2 4 进程上下文 2 5 进程家族树 3 进程的创建 4 进程的终结 5 线程的实现 1 概述 进程是执行期的代码 但是进程不止包括这样
  • supervisor系列:4、子进程

    supervisor系列 4 子进程 文章目录 supervisor系列 4 子进程 1 非后台运行的子进程 1 1 程序配置示例 1 1 1 Apache 2 2 6 1 1 2 Two Zope 2 X instances and on
  • supervisor入门教程

    supervisor是什么 是一个客户端 服务器系统 允许其用户在类UNIX操作系统上控制许多进程 官方解释 简单点来讲 就是一个监控脚本运行的工具 不过他可以统一化管理 laravel的队列文档上也有相关使用方式方法 例如 定时脚本的启动
  • supervisor系列:5、日志

    supervisor系列 5 日志 文章目录 supervisor系列 5 日志 1 活动日志 1 1 活动日志输出示例 1 2 活动日志等级 1 3 活动日志轮换 2 子进程日志 2 1 捕获模式 supervisord执行的主要任务之一

随机推荐

  • ICCV2021-TOCo-微软&CMU提出Token感知的级联对比学习方法,在视频文本对齐任务上“吊打”其他SOTA方法...

    关注公众号 发现CV技术之美 0 写在前面 对比学习已被广泛应用于训练基于Transformer的视觉语言模型的视频文本对齐和多模态表示学习等任务 在本文中 作者提出了一种新的token感知级联对比学习 TACo 算法 该算法利用两种技术改
  • 修改mysql连接回收时间_记一次生产环境数据库连接超时自动回收问题及解决方法...

    java sql SQLNonTransientConnectionException No operations allowed after connection closed at com mysql cj jdbc exception
  • ipykernel操控jupyter内核命令&在jupyter lab中使用conda创建的虚拟环境

    想在jupyter lab中使用conda创建的虚拟环境 只需要在命令行中激活环境 并且为其安装ipykernel即可 首先进入base环境中的jupyterlab给大家展示一下 并且给大家展示我所有的conda环境 其中 jupyter中
  • Java 多线程 --- 线程状态 Thread States

    Java 多线程 线程状态 Thread States New Threads Runnable Threads Blocked and Waiting Threads Terminated Threads New Threads 当用ne
  • 持续集成是什么?

    作者 阮一峰 日期 2015年9月23日 互联网软件的开发和发布 已经形成了一套标准流程 最重要的组成部分就是持续集成 Continuous integration 简称CI 本文简要介绍持续集成的概念和做法 一 概念 持续集成指的是 频繁
  • MyBatis流式查询

    MyBatis流式查询 1 应用场景说明 MyBatis preview JDBC三种读取方式 1 一次全部 默认 一次获取全部 2 流式 多次获取 一次一行 3 游标 多次获取 一次多行 在开发中我们经常需要会遇到统计数据 将数据导出到e
  • tomcat报错 Unable to process Jar entry

    错误描述 tomcat启动报下边的这个错 错误现象 09 Jul 2019 13 34 14 635 严重 RMI TCP Connection 3 127 0 0 1 org apache catalina startup Context
  • ORA-14402: 更新分区关键字列将导致分区的更改

    默认情况下 oracle的分区表对于分区字段是不允许进行update操作的 如果有对分区字段行进update 就会报错 ORA 14402 更新分区关键字列将导致分区的更改 但是可以通过打开表的row movement属性来允许对分区字段的
  • [JAVAee]Spring项目的创建与基本使用

    目录 Spring项目的创建 Spring中Bean对象的存储与获取 存储Bean对象 获取并使用Bean对象 getBean方法的重载 本文章介绍了Spring项目创建与使用的过程与一定的注意事项 Spring项目的创建 首先在IDEA中
  • 以太坊 Truffle实战

    目录 搭建私连网络 truflle初始化项目 智能合约示例 通用存证合约 初始化参数 接口 简易审批合约 初始化参数 数据结构 接口 智能合约的建立 谁在与智能合约交互 智能合约的销毁 整个过程主要演示chrome扩展 METAMASK O
  • 电源层和地线层完整性规则_电路设计规则

    电路图设计规则 一 电路设计流程 1 根据需求文件开始进行原理图设计 2 选择设计所需元器件 加载所需元件库 如果现有元件库没有所需元件 需自己制作 新制作的元器件要求功能形象化 标示准确化 选择合适的电路用于自己的设计完成相应的功能 确定
  • Unable to install breakpoint in XXX due to missing line number attributes.

    今天调试程序的时候 eclipse 弹出来一个 Unable to install breakpointdue to missingline number attributes Modify compileroptions togenera
  • 01.神经网络和深度学习——week2 神经网络基础(编程作业)

    Part 1 Python Basics with Numpy optional 1 Building basic functions with numpy 1 1 Sigmoid function np exp exe Build a f
  • Unity游戏开发客户端面经——C#(初级)

    前言 记录了总6w字的面经知识点 文章中的知识点若想深入了解 可以点击链接学习 由于文本太多 按类型分开 这一篇是C 常问问题总结 有帮助的可以收藏 1 引用类型 值类型 1 1 介绍 值类型 int bool float char str
  • 持续集成管理软件Jenkins应用实验

    编写Dockerfile文件 1 创建一个目录jenkins 保存相关的配置信息和内容 在 后输入mkdir Jenkins cd Jenkins命令 然后按Enter键 创建Jenkins目录并进入该目录 示例代码如下 root xian
  • UML建模与软件开发设计(七)——时序图设计

    在前面我们学习了类图相关知识 类图是一种静态结构模型视图 它是设计类及类间关系 即数据结构 的重要依据 但它无法刻画类的对象间的交互 通信行为 也就是说 类图无法描述类和类之间是如何通信 交互的 通俗地说 类图无法描述某个类的方法被哪个类所
  • OnTriggerEnter

    准备一个脚本 shiyan cs 脚本内容如下 脚本挂在小球上 然后运行场景 拖动小球撞盒子 然后再拖动盒子撞小球 分别看控制台打印结果 然后将脚本挂在盒子上 然后运行场景 拖动小球撞盒子 然后再拖动盒子撞小球 分别看控制台打印结果 OnT
  • 写一个Java程序,在程序中建立一个窗口

    编写一个Java程序 在程序中建立一个窗口 有四个文本框 两个按钮 单击 求和 按钮 能把第一个和第二个文本框的整数相加后结果显示在第三个文本框中 点击 复制 按钮 能将第三个文本框的内容复制到第四个文本框中 最后还可以正常关闭窗口 要创建
  • 后台管理系统----品牌管理

    目录 路由的搭建 品牌管理静态组件 品牌管理列表展示 element ui table表单组件 element ui el pagination分页器组件 插槽 网络请求 增删改牌静态页面 增删改品牌功能 书写api 增删改逻辑 表单校验
  • supervisor系列:4、子进程

    supervisor系列 4 子进程 文章目录 supervisor系列 4 子进程 1 非后台运行的子进程 1 1 程序配置示例 1 1 1 Apache 2 2 6 1 1 2 Two Zope 2 X instances and on