一、先安裝supervisor
1、安裝命令:
$ pip install supervisor
如果在沙盒環境下安裝不上的話使用:
$ apt-get install supervisor
二、安裝celery
$ pip install celery
三、對supervisor進行配置
1、生成默認配置文件
$ echo_supervisord_conf > /etc/supervisord.conf
在這里你也可以自定義默認配置文件生成的位置,前提是/etc目錄下先去創建你的要放置配置文件的目錄
假如我們創建了一個叫做supervisor的文件夾
然后將默認配置文件放到這個文件夾里面
$ 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
然后進入supervisord.conf.d文件夾,創建celeryd_worker.conf文件並進行如下配置:
[program:celeryworker] # 這個是進程的名字,隨意起 command=celery -A bookstore worker -l info # 要運行的命令 directory=/home/fhx/git_test1/bookstore # 運行命令的目錄 numprocs=1 # 設置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
下面是網上找的另外一個配置的例子,說得更加詳細一些:使用的是
[program: ProjectName] command=dotnet ProjectName.dll ; 運行程序的命令 directory=/root/Publishing/PublishOutput/ ; 命令執行的目錄 autorestart=true ; 程序意外退出是否自動重啟 autostart=true ; 是否自動啟動 stderr_logfile=/var/log/ProjectName.err.log ; 錯誤日志文件 stdout_logfile=/var/log/ProjectName.out.log ; 輸出日志文件 environment=ASPNETCORE_ENVIRONMENT=Production ; 進程環境變量 user=root ; 進程執行的用戶身份 stopsignal=INT startsecs=1 ; 自動重啟間隔
3、使用我們修改的配置文件啟動supervisor
supervisord -c /etc/supervisor/supervisord.conf
如果遇到報錯信息為端口正在被占用的話運行下面的命令
unlink /var/run/supervisor.sock # 或者 unlink /tmp/supervisor.sock
之后再運行上面的啟動supervisor命令
4、supervisorctl 命令來看我們supervisor的運行狀態
你將可以看到如下的顯示就表示你的后台celery已經啟動成功了:supervisorctl status
celeryworker RUNNING pid 17682, uptime 0:17:06
supervisorctl的使用就不在贅述了只說幾條簡單的命令:
status # 查看狀態
reread # 讀取配置信息
update # 加載最新的進程
stop # 停止進程
start # 啟動進程
reload # 重新加載配置
參考文檔: 1 https://www.jianshu.com/p/222d85c3833e
