supervisor安装(一)

tech2023-09-13  93

一、supervisor简介

Supervisor是用Python开发的一套通用的进程管理程序,能将一个普通的命令行进程变为后台daemon,并监控进程状态,异常退出时能自动重启。它是通过fork/exec的方式把这些被管理的进程当作supervisor的子进程来启动,这样只要在supervisor的配置文件中,把要管理的进程的可执行文件的路径写进去即可。也实现当子进程挂掉的时候,父进程可以准确获取子进程挂掉的信息的,可以选择是否自己启动和报警。supervisor还提供了一个功能,可以为supervisord或者每个子进程,设置一个非root的user,这个user就可以管理它对应的进程。

二、supervisor安装

安装方式1: 使用pip安装 curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py python get-pip.py pip install supervisor 方式2: 使用easy_install 安装 # 如果没有 easy_install 需要安装 python-setuptools $ yum install python-setuptools $ easy_install supervisor

配置

安装好supervisor之后,默认是没有生成配置文件的。可以通过以下命令生成配置文件, pip安装后echo_supervisord_conf在 ./bin 目录下

echo_supervisord_conf > /etc/supervisord.conf

我们通常是把配置文件放到/etc/下面,当然也可以放到任意路径下面。

# 设置默认配置 $ echo_supervisord_conf > /etc/supervisord.conf $ vim /etc/supervisord.conf

将此项加入末尾,supervisor 默认启动加载下列配置

[include] files = /data/supervisor/*.conf

创建文件夹

mkdir -p /data/supervisor

四、连接/启动

/usr/bin/supervisorctl -c /etc/supervisord.conf status # 查看状态 reload # 重新加载 restart [name/all] # 重启单个/所有 stop # 停止 start # 启动 update # 配置文件修改后可以使用该命令加载新的配置 help # 帮助命令

 

supervisor组件

supervisord 主进程,负责管理进程的server,它会根据配置文件创建指定数量的应用程序的子进程,管理子进程的整个生命周期,对crash的进程重启,对进程变化发送事件通知等。同时内置web server和XML-RPC Interface,轻松实现进程管理。。该服务的配置文件在/etc/supervisor/supervisord.conf。supervisorctl 客户端的命令行工具,提供一个类似shell的操作接口,通过它你可以连接到不同的supervisord进程上来管理它们各自的子程序,命令通过UNIX socket或者TCP来和服务通讯。用户通过命令行发送消息给supervisord,可以查看进程状态,加载配置文件,启停进程,查看进程标准输出和错误输出,远程操作等。服务端也可以要求客户端提供身份验证之后才能进行操作。Web Server supervisor提供了web server功能,可通过web控制进程(需要设置[inethttpserver]配置项)。XML-RPC Interface XML-RPC接口, 就像HTTP提供WEB UI一样,用来控制supervisor和由它运行的程序。

 

最新回复(0)