位置: 编程技术 - 正文

基于Python 的进程管理工具supervisor使用指南(基于python的研究)

编辑:rootadmin

推荐整理分享基于Python 的进程管理工具supervisor使用指南(基于python的研究),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:基于python的进销存管理系统,利用python进行,利用python进行,基于python的研究,基于python语言,利用python进行,基于python的算法,基于python语言,内容如对您有帮助,希望把文章链接给更多的朋友!

Supervisor 是基于 Python 的进程管理工具,只能运行在 Unix-Like 的系统上,也就是无法运行在 Windows 上。Supervisor 官方版目前只能运行在 Python 2.4 以上版本,但是还无法运行在 Python 3 上,不过已经有一个 Python 3 的移植版 supervisor-py3k。

什么情况下我们需要进程管理呢?就是执行一些需要以守护进程方式执行的程序,比如一个后台任务,我最常用的是用来启动和管理基于 Tornado 写的 Web 程序。

除此之外,Supervisor 还能很友好的管理程序在命令行上输出的日志,可以将日志重定向到自定义的日志文件中,还能按文件大小对日志进行分割。

Supervisor 有两个主要的组成部分:

supervisord,运行 Supervisor 时会启动一个进程 supervisord,它负责启动所管理的进程,并将所管理的进程作为自己的子进程来启动,而且可以在所管理的进程出现崩溃时自动重启。 supervisorctl,是命令行管理工具,可以用来执行 stop、start、restart 等命令,来对这些子进程进行管理。

安装

sudo pip install supervisor

创建配置文件

echo_supervisord_conf > /etc/supervisord.conf

如果出现没有权限的问题,可以使用这条命令

sudo su - root -c "echo_supervisord_conf > /etc/supervisord.conf"

配置文件说明

想要了解怎么配置需要管理的进程,只要打开 supervisord.conf 就可以了,里面有很详细的注释信息。

打开配置文件

vim /etc/supervisord.conf

默认的配置文件是下面这样的,但是这里有个坑需要注意,supervisord.pid 以及 supervisor.sock 是放在 /tmp 目录下,但是 /tmp 目录是存放临时文件,里面的文件是会被 Linux 系统删除的,一旦这些文件丢失,就无法再通过 supervisorctl 来执行 restart 和 stop 命令了,将只会得到 不存在的错误 。

默认情况下,进程的日志文件达到MB时,将进行分割,最多保留个文件,当然这些配置也可以对每个进程单独配置。

权限问题

设置好配置文件后,应先创建上述配置文件中新增的文件夹。如果指定了启动用户 user,这里以 oxygen 为例,那么应注意相关文件的权限问题,包括日志文件,否则会出现没有权限的错误。例如设置了启动用户 oxygen,然后启动 supervisord 出现错误

Error: Cannot open an HTTP server: socket.error reported errno.EACCES ()

就是由于上面的配置文件中 /var/run 文件夹,没有授予启动 supervisord 的用户 oxygen 的写权限。/var/run 文件夹实际上是链接到 /run,因此我们修改 /run 的权限。

sudo chmod /run

这样有点简单粗暴,也可以考虑把上述配置文件中 .sock,.pid 等文件修改到其他文件夹中,并确保有相应的权限即可。一般情况下,我们可以用 root 用户启动 supervisord 进程,然后在其所管理的进程中,再具体指定需要以那个用户启动这些进程。

使用浏览器来管理

supervisor 同时提供了通过浏览器来管理进程的方法,只需要注释掉如下几行就可以了。

使用 include

在配置文件的最后,有一个 [include] 的配置项,跟 Nginx 一样,可以 include 某个文件夹下的所有配置文件,这样我们就可以为每个进程或相关的几个进程的配置单独写成一个文件。

基于Python 的进程管理工具supervisor使用指南(基于python的研究)

进程的配置样例

一个简单的例子如下

设置日志级别

loglevel 指定了日志的级别,用 Python 的 print 语句输出的日志是不会被记录到日志文件中的,需要搭配 Python 的 logging 模块来输出有指定级别的日志。

多个进程

按照官方文档的定义,一个 [program:x] 实际上是表示一组相同特征或同类的进程组,也就是说一个 [program:x] 可以启动多个进程。这组进程的成员是通过 numprocs 和 process_name 这两个参数来确定的,这句话什么意思呢,我们来看这个例子。

上面这个例子会启动两个进程,process_name 分别为 foo:foo_ 和 foo:foo_。通过这样一种方式,就可以用一个 [program:x] 配置项,来启动一组非常类似的进程。

再介绍两个配置项 stopasgroup 和 killasgroup

; 默认为 false,如果设置为 true,当进程收到 stop 信号时,会自动将该信号发给该进程的子进程。如果这个配置项为 true,那么也隐含 killasgroup 为 true。例如在 Debug 模式使用 Flask 时,Flask 不会将接收到的 stop 信号也传递给它的子进程,因此就需要设置这个配置项。

更详细的配置例子,可以参考如下,官方文档在这里

将多个进程按组管理

Supervisor 同时还提供了另外一种进程组的管理方式,通过这种方式,可以使用 supervisorctl 命令来管理一组进程。跟 [program:x] 的进程组不同的是,这里的进程是一个个的 [program:x] 。

当添加了上述配置后,progname1 和 progname2 的进程名就会变成 thegroupname:progname1 和 thegroupname:progname2 以后就要用这个名字来管理进程了,而不是之前的 progname1。

以后执行 supervisorctl stop thegroupname: 就能同时结束 progname1 和 progname2,执行 supervisorctl stop thegroupname:progname1 就能结束 progname1。supervisorctl 的命令我们稍后介绍。

启动 supervisord

执行 supervisord 命令,将会启动 supervisord 进程,同时我们在配置文件中设置的进程也会相应启动。

更多参数请参考文档

supervisorctl 命令介绍

注意:显示用 stop 停止掉的进程,用 reload 或者 update 都不会自动重启。也可以参考这里

开机自动启动 Supervisord

Supervisord 默认情况下并没有被安装成服务,它本身也是一个进程。官方已经给出了脚本可以将 Supervisord 安装成服务,可以参考这里查看各种操作系统的安装脚本,但是我用官方这里给的 Ubuntu 脚本却无法运行。

安装方法可以参考 serverfault 上的回答。

比如我是 Ubuntu 系统,可以这么安装,这里选择了另外一个脚本

注意:这个脚本下载下来后,还需检查一下与我们的配置是否相符合,比如默认的配置文件路径,pid 文件路径等,如果存在不同则需要进行一些修改。

其实还有一个简单的方法,因为 Linux 在启动的时候会执行 /etc/rc.local 里面的脚本,所以只要在这里添加执行命令就可以

以上内容需要添加在 exit 命令前,而且由于在执行 rc.local 脚本时,PATH 环境变量未全部初始化,因此命令需要使用绝对路径。

在添加前,先在终端测试一下命令是否能正常执行,如果找不到 supervisord,可以用如下命令找到

sudo find / -name supervisord

Python自动化运维和部署项目工具Fabric使用实例 Fabric是使用Python开发的一个自动化运维和部署项目的一个好工具,可以通过SSH的方式与远程服务器进行自动化交互,例如将本地文件传到服务器,在服

python解决Fedora解压zip时中文乱码的方法 前言很多时候在windows下压缩文件没问题,但是到了Linux下,出现乱码,很常见。以前在Ubuntu下,用`unzip-OGBKfilename.zip`就可以搞定。换了Fedora后,暂时没

Python提取网页中超链接的方法 下面是最简单的实现方法,先将目标网页抓回来,然后通过正则匹配a标签中的href属性来获得超链接代码如下:importurllib2importreurl='

标签: 基于python的研究

本文链接地址:https://www.jiuchutong.com/biancheng/385357.html 转载请保留说明!

上一篇:打包发布Python模块的方法详解(python项目打包发布)

下一篇:Python自动化运维和部署项目工具Fabric使用实例(python自动化运维教程)

  • 印花税计入税金及附加还是应交税费
  • 房屋合同印花税税率属于个人交的吗
  • 怎么样办理银行卡?
  • 长期股权投资权益法下初始投资成本
  • 装饰设计事务所平面图
  • 用友软件销售操作流程
  • 交通费补贴报销的会计分录怎么做?
  • 个体工商户申报年报
  • 事业单位购入三年期国债的会计分录怎么做?
  • 小规模的企业所得税税率
  • 金穗开发票时怎样添加商品?
  • 进口关税发票账务处理如何进行?
  • 付款小于发票金额的原因
  • 安全生产费纳税调整政策
  • 增值税票查无此票是什么原因
  • 可转债税前收益和税后收益
  • 非流动资产基金是什么意思
  • 研发支出费用如何计算应交所得税?
  • 一次性劳务费需要交税吗
  • 厦门新车购置税计算
  • win7系统怎么进
  • c盘appdata怎么清理
  • 微pe工具箱怎么用
  • ccc.exe是什么进程
  • Linux系统中怎么开机自动运行拍摄文件
  • win10右键失灵解决办法
  • linux杀死程序
  • 记一次调试YOLOv5+DeepSort车辆跟踪项目的经过
  • php教程从入门到精通
  • pwcorr_a命令
  • 合同价格约定不明法律规定
  • 法定的盈余公积是什么
  • 零申报企业所得税季度申报表怎么填写
  • ubuntu下安装windows
  • 帝国cms怎么调用文章随机段落
  • 电脑管理费用入什么账户
  • 残疾人就业保障金上年职工工资总额
  • 一般纳税人企业所得税怎么征收
  • sql chr函数
  • sqlserver远程连接失败
  • 存货的计税基础公式
  • 原材料不良赔偿率怎么算
  • 行政单位怎样核销坏账
  • 预付账款是什么意思大白话
  • 小公司没有财务软件怎么手工记账
  • 研发设备的折旧计入研发费用吗
  • 长期待摊费用摊销会计分录
  • 差额征税问题
  • 加计减免其他收入怎么填
  • 安装生产流水线工程领用原材料
  • 一般纳税人采购分录
  • 用友t3计提折旧了没有生成凭证
  • 管家婆里面的记账凭证怎么做?
  • 为什么要缴纳残保金
  • 固定资产装修费用如果符合固定资产
  • 有偿服务职工怎么办
  • 职工体检费如何报销
  • mysql的增删改查命令
  • mysql修改表结构的命令
  • mysql中binlog_format模式与配置详细分析
  • win8如何激活
  • win8安装界面
  • xp系统能用谷歌吗
  • linux pwdx命令
  • directx?
  • fdreader.exe是什么程序
  • linux中快捷键
  • win7系统回收站文件夹的位置
  • Windows下自动备份MongoDB的批处理脚本
  • javascript模块化规范有哪些
  • core文件的作用
  • 常用dos命令大全及用法
  • 提高css文件可维性的方法
  • javascript如何输出变量
  • nodejs接入微信支付
  • nodejs邮件
  • 基于android开发
  • 河南省政府非税收网站
  • 医疗机构执业许可证办理的条件
  • 提供劳务者受害责任纠纷赔偿案例
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设