由于本机测试代码,但执行的进程频繁挂掉。现有线上项目使用supervisor保活进程,所以打算尝试下mac上安装配置supervisor。
参考了这篇文章:http://blog.csdn.net/hylexus/article/details/78177649?locationNum=7&fps=1
安装:brew install supervisor
自动随系统启动:brew services start supervisor
也可以 手动启动:
supervisord-c /usr/local/etc/supervisord.ini
supervisorctl -c /usr/local/etc/supervisord.ini
进入supervisor
重启:reload
启动某个进程:start logstash(脚本名)
停止某个进程:stop logstash(脚本名)
如何准备脚本:logstash
vim /usr/local/etc/supervisor.d/logstash.ini
[program:logstash]
directory = /Users/sina/test
command = /bin/bash /Users/sina/test/test2.sh
autostart = false
startsecs = 5
autorestart = true
startretries = 3
user = jiangdan
redirect_stderr = true
stdout_logfile_backups = 20
stdout_logfile=/usr/local/var/log/testPopQueue.log
stdout_logfile_maxbytes=10MB
stderr_logfile=/usr/local/var/log/testPopQueue-err.log
stderr_logfile_maxbytes=10MB
; environment=PYTHONPATH=$PYTHONPATH:/path/to/somewhere
如果写user,user必须是所运行脚本的所有者,比如supervisor守护redis、memcache可以不写user
supervisor守护redis时,需要把redis.conf的demonize改成no,由supervisor监管的进程都不能是-d 后台守护进程
由于我的php脚本中用到了redis、memcache、memcacheq,且php是个常驻进程。这里用supervisr配置了php本身的守护进程、redis和memcache的守护进程,本来想配置memcacheq的守护进程,可一直没成功。。。
整体弄到一半,达到了用supervisor守护php、redis、memcacheq的目的,先记录总结下
在/usr/local/etc/supervisor.d目录中,配置了php的ini文件(logstash.ini)、memcache.ini、redis.ini
由于logstash里的command用shell命令执行一直出错(shell里也是调用php脚本执行),这里干脆把command部分改成php命令执行脚本
logstash.ini配置如下:
[program:logstash]
directory = /Users/sina/Code/msg-new/codes/host/protected/
command = /usr/local/Cellar/php72/7.2.1_12/bin/php /Users/sina/Code/msg-new/codes/host/protected/yiic.php customMsgQuickSender startOneSender --queueFlag=111 --type=notManual >> /Users/sina/test/yiic.log.err 2>&1 &
autostart = false
startsecs = 5
autorestart = true
startretries = 3
user = jiangdan
redirect_stderr = true
stdout_logfile_backups = 20
stdout_logfile=/usr/local/var/log/testPopQueue.log
stdout_logfile_maxbytes=10MB
;stderr_logfile=/usr/local/var/log/testPopQueue-err.log
;stderr_logfile_maxbytes=10MB
; environment=PYTHONPATH=$PYTHONPATH:/path/to/somewhere
redis.ini配置如下:
[program:redis]
;directory = /Users/sina/Code/msg-new/codes/host/protected/
command = /usr/local/Cellar/redis@3.2/3.2.11/bin/redis-server /usr/local/etc/redis.conf
autostart = true
startsecs = 5
autorestart = true
startretries = 3
;user = jiangdan
;redirect_stderr = true
;stdout_logfile_backups = 20
;stdout_logfile=/usr/local/var/log/testPopQueue.log
;stdout_logfile_maxbytes=10MB
;stderr_logfile=/usr/local/var/log/testPopQueue-err.log
;stderr_logfile_maxbytes=10MB
; environment=PYTHONPATH=$PYTHONPATH:/path/to/somewhere
memcache.ini配置如下:
[program:memcache]
;directory = /Users/sina/Code/msg-new/codes/host/protected/
command = /usr/local/bin/memcached -m 2048 -u root -c 1024 -p 11211
autostart = true
startsecs = 5
autorestart = true
startretries = 3
;user = root
;redirect_stderr = true
;stdout_logfile_backups = 20
;stdout_logfile=/usr/local/var/log/testPopQueue.log
;stdout_logfile_maxbytes=10MB
;stderr_logfile=/usr/local/var/log/testPopQueue-err.log
;stderr_logfile_maxbytes=10MB
; environment=PYTHONPATH=$PYTHONPATH:/path/to/somewhere
注意看command中redis和memcache配置中的command命令原来是有-d的,这里用supervisor守护进程,命令中都已经去掉了-d
遇到问题检查错误日志:
tail /usr/local/var/log/supervisord.log
检查logstash脚本中定义的输出以及错误文件,还有就是查看shell脚本本身的问题