位置: 编程技术 - 正文

基于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自动化运维教程)

  • 申报未抄税
  • 支付城镇土地使用税会计科目
  • 小微企业应纳税所得额怎么计算
  • 公司章程在工商局
  • 小规模销售收入免税会计分录
  • 一般纳税人主表第一栏数据
  • 视同内销补税的财务处理
  • 已认证未抵扣的进项怎么填写
  • 申报更正日期改变会导致逾期申报吗
  • 收到银行汇票要去银行办理吗
  • 二次股权转让的股权原值确认
  • 购货发票属于什么科目
  • 企业所得税公益捐赠扣除限额
  • 全额税前扣除的公益捐赠有几类
  • 收到补价时应确认收益,支付补价时不能确认收益
  • 企业递延所得税费用的计算公式
  • 纸质承兑怎么收付
  • 固定资产已折旧完报废如何处理
  • 跨地区预缴税款需缴纳哪些
  • 自然人股权转让涉税信息怎么填
  • 补缴税款罚款
  • 发票的金额可以答应客户多开
  • 已认证的发票如何冲红
  • 建筑业增值税税率2022
  • 小规模纳税人补缴增值税
  • 小微企业销售额含税吗
  • 俱乐部会员有什么用
  • 有没有薪酬
  • 发票过期一年可以用吗
  • 小规模增值税未开票收入填哪里
  • 计提了坏账准备对利润的影响
  • 小规模需要交所得税吗
  • windows11怎么快速截屏
  • 要求快速启动
  • 预付款无法收回账务处理
  • php如何通过链接获取源码
  • win7旗舰版系统怎么样
  • 哥德堡的港口
  • php版本7和5区别
  • php读取文件内容
  • laravel 实例
  • 宝塔怎么做?
  • 什么情况下要开外经证
  • 垃圾处理费计提吗
  • 城市维护建设税是什么意思
  • day14-HTTP01
  • 个体户电子申报税流程
  • 兼职会计人员的职责
  • 以前年度应收账款错误如何调整
  • 转账进公户
  • 报表与账不符情况说明
  • 公司收到现金货款怎么存银行
  • 旅行社代订机票便宜吗
  • 发票认证是为了什么
  • 研发费用账务处理实例
  • 哪些企业执行新的租赁政策
  • mysql数据库设置固定值
  • win7系统怎么设置开机启动项
  • 启用与禁用的英文
  • freebsd怎么样
  • linux vs windows
  • linux,windows
  • powerremind.exe
  • win10系统无法进入
  • shell脚本中的数组
  • opengl sharder
  • opengl 位图
  • 关于减肥的好方法
  • js怎么使用
  • 关于中秋节的古诗
  • linux安装nodejs xz格式
  • android安卓应用程序窗口化
  • python 备份文件夹
  • 专票增额怎么办手续
  • 青岛税务局局长是什么级别?
  • 租房减免税收
  • 地方税务局工作内容
  • 山东水利建设基金减免政策
  • 仓储用地和物流用地划分
  • 餐饮办税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设