mac上安装配置supervisor总结

由于本机测试代码,但执行的进程频繁挂掉。现有线上项目使用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脚本本身的问题

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值