使用supervisor后臺運(yùn)行celery
一拘鞋、先安裝supervisor
1拇涤、安裝命令:
$ pip install supervisor
如果在沙盒環(huán)境下安裝不上的話使用:
$ apt-get install supervisor
二趾访、安裝celery
$ pip install celery
三吼驶、對supervisor進(jìn)行配置
1、生成默認(rèn)配置文件
$ echo_supervisord_conf > /etc/supervisord.conf
在這里你也可以自定義默認(rèn)配置文件生成的位置少办,前提是/etc目錄下先去創(chuàng)建你的要放置配置文件的目錄
假如我們創(chuàng)建了一個叫做supervisor的文件夾
然后將默認(rèn)配置文件放到這個文件夾里面
$ echo_supervisord_conf > /etc/supervisor/supervisord.conf
2苞慢、修改配置文件
$ vim /etc/supercisor/supervisord.conf
在最后一行添加
files = /etc/supervisor/supervisord.conf.d/*.conf
[include]
;files = /etc/supervisor/conf.d/*.conf
files = /etc/supervisor/supervisord.conf.d/*.conf
然后進(jìn)入supervisord.conf.d文件夾,創(chuàng)建celeryd_worker.conf文件并進(jìn)行如下配置:
[program:celeryworker] # 這個是進(jìn)程的名字英妓,隨意起
command=celery -A bookstore worker -l info # 要運(yùn)行的命令
directory=/home/fhx/git_test1/bookstore # 運(yùn)行命令的目錄
numprocs=1
# 設(shè)置log的路徑
stdout_logfile=/var/log/supervisor/celeryworker.log
stderr_logfile=/var/log/supervisor/celeryworker.log
autostart=true
autorestart=true
startsecs=10
stopwaitsecs = 600
priority=15
下面是網(wǎng)上找的另外一個配置的例子挽放,說得更加詳細(xì)一些:使用的是
[program: ProjectName]
command=dotnet ProjectName.dll ; 運(yùn)行程序的命令
directory=/root/Publishing/PublishOutput/ ; 命令執(zhí)行的目錄
autorestart=true ; 程序意外退出是否自動重啟
autostart=true ; 是否自動啟動
stderr_logfile=/var/log/ProjectName.err.log ; 錯誤日志文件
stdout_logfile=/var/log/ProjectName.out.log ; 輸出日志文件
environment=ASPNETCORE_ENVIRONMENT=Production ; 進(jìn)程環(huán)境變量
user=root ; 進(jìn)程執(zhí)行的用戶身份
stopsignal=INT
startsecs=1 ; 自動重啟間隔
3、使用我們修改的配置文件啟動supervisor
supervisord -c /etc/supervisor/supervisord.conf
如果遇到報(bào)錯信息為端口正在被占用的話運(yùn)行下面的命令
unlink /var/run/supervisor.sock
# 或者
unlink /tmp/supervisor.sock
之后再運(yùn)行上面的啟動supervisor命令
4蔓纠、supervisorctl 命令來看我們supervisor的運(yùn)行狀態(tài)
你將可以看到如下的顯示就表示你的后臺celery已經(jīng)啟動成功了
celeryworker RUNNING pid 17682, uptime 0:17:06
supervisorctl的使用就不在贅述了只說幾條簡單的命令:
status # 查看狀態(tài)
reread # 讀取配置信息
update # 加載最新的進(jìn)程
stop # 停止進(jìn)程
start # 啟動進(jìn)程
reload # 重新加載配置
四辑畦、還有一個坑
1、第二天我發(fā)現(xiàn)了一個bug
就在我第二天打開我的服務(wù)器運(yùn)行supervisorctl時發(fā)現(xiàn)報(bào)錯了贺纲,
unix:///tmp/supervisor.sock no such file
然后我再去我部署的網(wǎng)站上去測試發(fā)現(xiàn)celery并沒有掛航闺,
以下是網(wǎng)上的說法:
在supervisor默認(rèn)配置中,其啟動的sock等都會放到tmp目錄猴誊,而tmp目錄會自動清理導(dǎo)致無法使用supervisorctl命令。
此時:修改supervisor.conf文件侮措,修改到/var/run/及/var/log/目錄懈叹,具體配置就不進(jìn)行貼了,簡單直接搜索tmp進(jìn)行修改即可分扎。重啟supervisor服務(wù)澄成,記得kill原來服務(wù)。
<b>我并沒有按照這種方式進(jìn)行修改畏吓,只是進(jìn)入supervisorctl運(yùn)行了一次reload之后就好了墨状。