CentOS supervisor 安装与配置 (Laravel 队列示例)

参考文档

https://learnku.com/laravel/t/2126/supervisor-installation-configuration-use

安装

yum install supervisor

配置文件目录

/etc/
    supervisor.conf
    supervisor.d/
        项目一.ini
        项目二.ini

laravel 队列配置示例

说明, user=www 为启动的 php artisan 进程执行用户,这个要和 php 执行用户使用一个,而supervisor 启动用户为 root, 配置在 supervisor.conf 文件中,stdout 等日志文件创建者均为 supervisor 用户,即 root

supervisor 主配置文件路径为/var/log/supervisor/supervisord.log(版本间可能不同,请查看主配置文件/etc/supervisor.conf logfile 配置项),写 stdout 等日志路径时,可使用 /var/log/supervisor/{programname 即 smallnews}.log

[program:smallnews]
process_name=%(program_name)s_%(process_num)02d
command=/usr/local/php/bin/php /data/html/smallnews/artisan queue:work database --sleep=3 --tries=3 --daemon
numprocs=3
autostart=true
autorestart=true
user=www
redirect_stderr=true
stdout_logfile=/var/log/supervisor/smallnews.log
stderr_logfile=/var/log/supervisor/smallnews_err.log

启动与停止

stop 之后相关的进程全部被杀死,restart 相关进程全部重启

开机自启动

systemctl enable supervisord

启动停止重启

systemctl start|stop|restart supervisord

状态

systemctl status supervisord

状态信息

正在运行

● supervisord.service - Process Monitoring and Control Daemon
   Loaded: loaded (/usr/lib/systemd/system/supervisord.service; disabled; vendor preset: disabled)
   Active: active (running) since Sat 2019-05-25 17:53:33 CST; 1min 34s ago
  Process: 20182 ExecStart=/usr/bin/supervisord -c /etc/supervisord.conf (code=exited, status=0/SUCCESS)
 Main PID: 20185 (supervisord)
   CGroup: /system.slice/supervisord.service
           ├─20185 /usr/bin/python /usr/bin/supervisord -c /etc/supervisord.conf
           ├─20186 /usr/local/php/bin/php /data/html/smallnews/artisan queue:work database --sleep=3 --tries=3 --daemon
           ├─20187 /usr/local/php/bin/php /data/html/smallnews/artisan queue:work database --sleep=3 --tries=3 --daemon
           └─20188 /usr/local/php/bin/php /data/html/smallnews/artisan queue:work database --sleep=3 --tries=3 --daemon

停止运行

● supervisord.service - Process Monitoring and Control Daemon
   Loaded: loaded (/usr/lib/systemd/system/supervisord.service; disabled; vendor preset: disabled)
   Active: inactive (dead)

查看启动的进程

主进程
#> ps -ef | grep supervisor
root     23668     1  0 18:29 ?        00:00:00 /usr/bin/python /usr/bin/supervisord -c /etc/supervisord.conf

子进程 即 supervisor 坚守的进程
#> ps -ef | grep artisan
www      23669 23668  0 18:29 ?        00:00:00 /usr/local/php/bin/php /data/html/smallnews/artisan queue:work database --sleep=3 --tries=3 --daemon
www      23670 23668  0 18:29 ?        00:00:00 /usr/local/php/bin/php /data/html/smallnews/artisan queue:work database --sleep=3 --tries=3 --daemon
www      23671 23668  0 18:29 ?        00:00:00 /usr/local/php/bin/php /data/html/smallnews/artisan queue:work database --sleep=3 --tries=3 --daemon

网页查看状态

[inet_http_server]         ; inet (TCP) server disabled by default
port=0.0.0.0:9001          ; (ip_address:port specifier, *:port for all iface)
username=user              ; 用户名 (default is no username (open server))
password=123               ; 密码 (default is no password (open server))

访问网址查看 Supervisor status,可直接操作启动,重启,停止等指令

ip:9001 
账号:user
密码:123
State Description Name Action
running pid 22506, uptime 0:00:28 smallnews:smallnews_00 Restart Stop Clear Log Tail -f
running pid 22505, uptime 0:00:28 smallnews:smallnews_01 Restart Stop Clear Log Tail -f
running pid 22504, uptime 0:00:28 smallnews:smallnews_02 Restart Stop Clear Log Tail -f

配置项说明

摘取至上面文档

;*为必须填写项
;*[program:应用名称]
[program:cat]
;*命令路径,如果使用python启动的程序应该为 python /home/test.py, 
;不建议放入/home/user/, 对于非user用户一般情况下是不能访问
command=/bin/cat
;当numprocs为1时,process_name=%(program_name)s
;当numprocs>=2时,%(program_name)s_%(process_num)02d
process_name=%(program_name)s
;进程数量
numprocs=1
;执行目录,若有/home/supervisor_test/test1.py
;将directory设置成/home/supervisor_test
;则command只需设置成python test1.py
;否则command必须设置成绝对执行目录
directory=/tmp
;掩码:--- -w- -w-, 转换后rwx r-x w-x
umask=022
;优先级,值越高,最后启动,最先被关闭,默认值999
priority=999
;如果是true,当supervisor启动时,程序将会自动启动
autostart=true
;*自动重启
autorestart=true
;启动延时执行,默认1秒
startsecs=10
;启动尝试次数,默认3次
startretries=3
;当退出码是0,2时,执行重启,默认值0,2
exitcodes=0,2
;停止信号,默认TERM
;中断:INT(类似于Ctrl+C)(kill -INT pid),退出后会将写文件或日志(推荐)
;终止:TERM(kill -TERM pid)
;挂起:HUP(kill -HUP pid),注意与Ctrl+Z/kill -stop pid不同
;从容停止:QUIT(kill -QUIT pid)
;KILL, USR1, USR2其他见命令(kill -l),说明1
stopsignal=TERM
stopwaitsecs=10
;*以root用户执行,如果是 php 相关进程,请使用 php 启动用户
user=root
;重定向
redirect_stderr=false
stdout_logfile=/a/path
stdout_logfile_maxbytes=1MB
stdout_logfile_backups=10
stdout_capture_maxbytes=1MB
stderr_logfile=/a/path
stderr_logfile_maxbytes=1MB
stderr_logfile_backups=10
stderr_capture_maxbytes=1MB
;环境变量设置
environment=A="1",B="2"
serverurl=AUTO

常见问题

问题一 启动报错

描述

#> systemctl restart supervisord

Job for supervisord.service failed because the control process exited with error code. See "systemctl status supervisord.service" and "journalctl -xe" for details

#> systemctl status supervisord.service

supervisord.service - Process Monitoring and Control Daemon
   Loaded: loaded (/usr/lib/systemd/system/supervisord.service; disabled; vendor preset: disabled)
   Active: failed (Result: exit-code) since Sat 2019-05-25 18:23:46 CST; 13s ago
  Process: 23126 ExecStart=/usr/bin/supervisord -c /etc/supervisord.conf (code=exited, status=2)
 Main PID: 22502 (code=exited, status=0/SUCCESS)

May 25 18:23:46 VM_115_62_centos systemd[1]: Starting Process Monitoring and Control Daemon...
May 25 18:23:46 VM_115_62_centos supervisord[23126]: Error: section [inet_http_server] has no port value
May 25 18:23:46 VM_115_62_centos supervisord[23126]: For help, use /usr/bin/supervisord -h
May 25 18:23:46 VM_115_62_centos systemd[1]: supervisord.service: control process exited, code=exited status=2
May 25 18:23:46 VM_115_62_centos systemd[1]: Failed to start Process Monitoring and Control Daemon.
May 25 18:23:46 VM_115_62_centos systemd[1]: Unit supervisord.service entered failed state.
May 25 18:23:46 VM_115_62_centos systemd[1]: supervisord.service failed.

从上面得出报错信息为

Error: section [inet_http_server] has no port value

解决

如果存在 [inet_http_server] 则必须存在 127.0.0.1::9001 或者 0.0.0.0:9001,即必须启动这个监听进程

如果想关掉 必须把 [inet_http_server] 注释掉,即最前面加 “;”

本作品采用《CC 协议》,转载必须注明作者和本文链接
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!