标签: Centos, supervisor
-
作者帖子
-
中午看到有客户下完单整个 http://www.weixiaoduo.com 网站就无法访问了,当时就是一脸懵逼,我还啥危险操作都没做呢,
难道说是被人黑了?
还是说服务器欠费宕机了?
又或是安全软件执行什么操作导致的?
再有是不是WordPress 哪个插件出了问题???
……一系列猜测花了差不多一分钟时间,然后赶紧先打开FTP 进服务器看了下,发现可以登录那么就是说服务器状态正常没欠费,然后试着把 WordPress 的插件目录改了下名称,但还是依旧 500 无法访问。
再来有点儿着急了,因为我们站是实时都有客户访问的,上面问题测试完后,考虑要不要重启服务器,突然灵光一闪,是不是哪个服务给退出了??????
然后赶紧进 SSH ,试着重启 Nginx 服务,然后再重启 PHP 服务,刷新网页,可以正常访问了。
还真就是 PHP 给异常退出的缘故。这此几分钟无法访问,让我稍微有点儿措手不及,因为从去年更新服务器到现在还是头一回因为服务器软件退出导致的问题。
那么还得想办法解决下,网上找了找发现有个 supervisor 可以进行特定进程的任务守护。
楼下就简单贴下配置信息。
#安装setuptools yum install python-setuptools #安装supervisor easy_install supervisor #测试安装是否成功: echo_supervisord_conf #上面语句若输出配置文件信息表示安装成功 #创建supervisor配置文件 echo_supervisord_conf > /etc/supervisord.conf #修改配置文件: #在supervisord.conf最后增加: [program:php] command = php ;需要执行的命令 autostart=true ;supervisor启动的时候是否随着同时启动 autorestart=true ;当程序跑出exit的时候,这个program会自动重启 startsecs=1 ;程序重启时候停留在runing状态的秒数 startretries=3 ;启动失败自动重试次数,默认是 3 redirect_stderr=true ;把 stderr 重定向到 stdout,默认 false stdout_logfile=/mnt/hgfs/htdocs/logs/stdout.log ;stdout 日志文件 stderr_logfile=/mnt/hgfs/htdocs/logs/stderr.log # 队列消费 [program:queue_dispose] command = /usr/local/php/bin/php /alidata/www/artisan queue:work --daemon --sleep=3 --tries=3 process_name = %(program_name)s_%(process_num)s numprocs = 6 ;启动6个进程 autostart = true autorestart = true stdout_logfile = /alidata/log/php/supervisor_queue_dispose_out.log stdout_logfile_maxbytes = 10MB redirect_stderr=true [program:dsj_spider] command=/usr/local/php/bin/php /mnt/hgfs/htdocs/www.test.com/index.php autostart=false autorestart=false startsecs=1 ;启动 1 秒后没有异常退出,就当作已经正常启动了 startretries=3 redirect_stderr=true stdout_logfile=/mnt/hgfs/htdocs/logs/stdout.log stderr_logfile=/mnt/hgfs/htdocs/logs/stderr.log #除以上将进程配置添加到supervisord.conf文件中 #推荐将各个进程配置放到单独的文件中,然后通过[include]配置项引用 [include] files = /etc/supervisor/*.conf #其他配置具体看/etc/supervisord.conf文件
#supervisor服务启动 supervisord -c /etc/supervisord.conf #supervisor服务客户端管理 supervisorctl # 重新启动配置中的所有程序 sudo supervisorctl reload # 终止配置中的所有进程 sudo supervisorctl stop all # 启动配置中的所有进程 sudo supervisorctl start all
亮点:web管理界面
supervisor提供web管理页面,可以在网页端对进程进行监控,启动,终止,重启等操作
将supervisord.conf中[inet_http_server]部分做相应配置,在supervisorctl中reload即可启动web管理界面
[inet_http_server] ; inet (TCP) server disabled by default port=192.168.10.129:9001 ; 外网ip(ip_address:port specifier, *:port for all iface) username=xxxxxxx ; (default is no username (open server)) password=xxxxxxx ; (default is no password (open server))
在浏览器打开网址192.168.10.129:9001,输入上面账号xxxxxxx密码xxxxxxx,即可进入web管理页面:
注意:
1、每次修改配置文件后需进入supervisorctl,执行reload, 改动部分才能生效
2、Supervisor主要有两个命令:
supervisord : 启动supervisor的服务器端
supervisorctl:启动supervisor的命令行窗口,在该命令行中可执行start、stop、status、reload等操作。3、php脚本执行报’BACKOFF Exited too quickly (process log may have details)’错误解决:
对于执行时间很短的php脚本,点击进程执行会报以上错误<?php require 'db.class.php'; $dbHost = 'localhost'; $dbUser = 'xxxxxx'; $dbPasswd = 'xxxxxx'; $dbName = 'test'; $pdo = db::getInstance($dbHost, $dbUser, $dbPasswd, $dbName); $pdo->insert('test', ['name' => 'wml']); sleep(2); #在php脚本最后一行加上一句,可解决该问题
supervisor缺点:
1. 单机监控
2. 只能从supervisor启动的程序才能监控,从其他地方启动的无法监控
可以使用阿里云监控 supervisord 进程, supervisord进程 监控各子进程其他监控工具如 monit ,功能更加强大。等以后研究
-
作者帖子
- 哎呀,回复话题必需登录。