关于supervisor 的使用以及配置

 

首先我个人认为,用python实现的supervisor使用了守护进程这个概念去实现一个包裹进程的概念。

他可以帮助你的进程完成失效重启,日志记录,确保在线,关机自启动等一系列的功能。

 

当使用supervisor的进程死掉的时候,启动他的守护进程可以帮助你重新完成启动该进程的工作,不必再重复的手动去启这个进程,大大的提升了稳定性。

所以可以这样理解,supervisor进程本身是作为被他启动进程的守护进程存在的,只要他不死,他就能提升进程的稳定性。

 

说了这么多让我大概谈一下如何使用和如何配置。

首先我是使用的pip 安装的,我这里先介绍使用pip安装的流程和使用的方法。

使用pip install supervisor安装supervisor

然后supervisor会自动被加到etc/local/bin里 然后可以使用两个命令

1. supervisord

2. supervisorctl

 

我暂时不谈这两个命令的用途继续向前。

我用电脑切换到root权限,使用命令

echo_supervisord_conf > /etc/supervisord.conf

在etc目录下面生成一个supervisord的配置文件,该配置文件可以被用来启动supervisor进程。

 

那。。道理我都懂,为什么还看到过一些自己写的配置文件呢like this。。

 

[program:usercenter]
directory = /home/leon/projects/usercenter ; 程序的启动目录
command = gunicorn -c gunicorn.py wsgi:app  ; 启动命令,可以看出与手动在命令行启动的命令是一样的
autostart = true     ; 在 supervisord 启动的时候也自动启动
startsecs = 5        ; 启动 5 秒后没有异常退出,就当作已经正常启动了
autorestart = true   ; 程序异常退出后自动重启
startretries = 3     ; 启动失败自动重试次数,默认是 3
user = leon          ; 用哪个用户启动
redirect_stderr = true  ; 把 stderr 重定向到 stdout,默认 false
stdout_logfile_maxbytes = 20MB  ; stdout 日志文件大小,默认 50MB
stdout_logfile_backups = 20     ; stdout 日志文件备份数
; stdout 日志文件,需要注意当指定目录不存在时无法正常启动,所以需要手动创建目录(supervisord 会自动创建日志文件)
stdout_logfile = /data/logs/usercenter_stdout.log
 
; 可以通过 environment 来添加需要的环境变量,一种常见的用法是修改 PYTHONPATH
; environment=PYTHONPATH=$PYTHONPATH:/path/to/somewhere

 

这里写了一个app 注意,[program:project-name]

这个是固定名字,告诉supervisor这个program的名字是什么,这个名字会在你使用supervisorctl的时候标识这个项目的名称。

 

只需要编辑一下我们放在/etc下的supervisord.conf配置文件就行了。

仔细察看配置文件内容不难发现,在最后有一个[include]模块,

在下面依照这种格式,就可以让启动该配置文件的事以后搜索这个路径下面的app一并启动

[include]
files = /Users/piperck/Desktop/tools/sa/*.conf 

配置好了之后,让我们来启动他,直接使用命令

supervisord -c /etc/supervisord.conf

supervisord 就可以启动啦!

 

还有另外一种简单的方法,直接使用apt-get install supervisor来安装supervisor 这样配置文件会直接出线在/etc/supervisor中

我们只需要配置etc/supervisor/conf.d/xx.conf就可以 配置supervisor了

而且这样还有一个好处是可以直接使用系统service 对supervisor进行开启关闭重启 也可以使用控制台 比较灵活。

 

记得还有一个命令没有介绍到,那就是supervisorctl顾名思义,就是supervisor的控制台。

输入之后进入控制题啊,然后使用help命令可以轻松看到有哪些命令可以使用。

 

> status    # 查看程序状态
> stop       # 关闭程序
> start       # 启动程序
> restart    # 重启程序
> reread    # 读取有更新(增加)的配置文件,不会启动新添加的程序
> update    # 重启配置文件修改过的程序

 

另外可能会在该配置文件里面看到很多以“;” 开头的。这个符号在这里是注释掉的意思。

就这样supervisor就被启动起来了,效果也很明显,用来做什么也很明显,更多参数和高级用法,还是在实践中查询文档实现吧!

要在Laravel项目中使用Supervisor进行进程管理,你可以按照以下步骤进行配置: 1. 确保已经安装了Supervisor。可以使用以下命令检查是否已安装: ``` supervisorctl --version ``` 2. 创建一个新的Supervisor配置文件。可以使用以下命令创建一个新的配置文件: ``` sudo nano /etc/supervisor/conf.d/laravel-worker.conf ``` 3. 在配置文件中添加以下内容,替换其中的路径和命令为你的实际情况: ``` [program:laravel-worker] process_name=%(program_name)s_%(process_num)02d command=php /path/to/artisan queue:work --tries=3 autostart=true autorestart=true numprocs=8 redirect_stderr=true stdout_logfile=/path/to/storage/logs/worker.log ``` 以上配置将创建一个名为"laravel-worker"的进程组,使用`php /path/to/artisan queue:work --tries=3`命令启动Laravel队列工作进程。`numprocs=8`表示创建8个进程实例。 4. 保存并关闭文件。 5. 重新加载Supervisor配置文件。使用以下命令重新加载配置文件: ``` sudo supervisorctl reread sudo supervisorctl update ``` 6. 启动和管理Laravel队列工作进程使用以下命令启动、停止或重启Laravel队列工作进程: ``` sudo supervisorctl start laravel-worker:* sudo supervisorctl stop laravel-worker:* sudo supervisorctl restart laravel-worker:* ``` 7. 查看进程状态和日志。使用以下命令检查Laravel队列工作进程状态和日志输出: ``` sudo supervisorctl status laravel-worker:* tail -f /path/to/storage/logs/worker.log ``` 这样,你就可以使用Supervisor管理Laravel项目中的队列工作进程了。确保按照实际情况修改配置文件中的路径和命令,并注意日志文件的路径设置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值