進程管理工具supervisor的安裝與使用教程

  supervisor是用python寫的一個進程管理工具,用來啓動,重啓,關閉進程。下面這篇文章主要給你們介紹了關於python實現的進程管理工具supervisor的安裝與使用的相關資料,須要的朋友能夠參考借鑑,下面來一塊兒看看吧。python

  前言web

  在一個分佈式環境中,每臺機器上可能須要啓動和中止多個進程,使用命令行方式一個一個手動啓動和中止很是麻煩,並且查看每一個進程的狀態也很不方便。若是有一個工具可以實現每臺機器上多個進程的簡單高效中心化管理將是很是方便的。因而Supervisord工具應運而生。與Supervisord相似的工具包括monit,daemontools和runit。下面話很少說,來一塊兒看看詳細的介紹吧。瀏覽器

  安裝安全

  Supervisord是運行在Python環境下的服務監控程序,因此在安裝supervisord以前必須有python環境。服務器

yum install python-setuptools
easy_install supervisor

 

若是安裝成功,鍵入:echo_supervisord_conf,會顯示一個superviscord_conf 的配置模板。app

  配置文件詳解socket

[unix_http_server]
file=/tmp/supervisor.sock ; UNIX socket 文件,supervisorctl 會使用
;chmod=0700 ; socket 文件的 mode,默認是 0700
;chown=nobody:nogroup ; socket 文件的 owner,格式: uid:gid
;[inet_http_server] ; HTTP 服務器,提供 web 管理界面
;port=127.0.0.1:9001 ; Web 管理後臺運行的 IP 和端口,若是開放到公網,須要注意安全性
;username=user ; 登陸管理後臺的用戶名
;password=123 ; 登陸管理後臺的密碼
[supervisord]
logfile=/tmp/supervisord.log ; 日誌文件,默認是 $CWD/supervisord.log
logfile_maxbytes=50MB ; 日誌文件大小,超出會 rotate,默認 50MB
logfile_backups=10 ; 日誌文件保留備份數量默認 10
loglevel=info ; 日誌級別,默認 info,其它: debug,warn,trace
pidfile=/tmp/supervisord.pid ; pid 文件
nodaemon=false ; 是否在前臺啓動,默認是 false,即以 daemon 的方式啓動
minfds=1024 ; 能夠打開的文件描述符的最小值,默認 1024
minprocs=200 ; 能夠打開的進程數的最小值,默認 200
; the below section must remain in the config file for RPC
; (supervisorctl/web interface) to work, additional interfaces may be
; added by defining them in separate rpcinterface: sections
[rpcinterface:supervisor]
supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface
[supervisorctl]
serverurl=unix:///tmp/supervisor.sock ; 經過 UNIX socket 鏈接 supervisord,路徑與 unix_http_server 部分的 file 一致
;serverurl=http://127.0.0.1:9001 ; 經過 HTTP 的方式鏈接 supervisord
; 包含其餘的配置文件
[include]
files = relative/directory/*.ini ; 能夠是 *.conf 或 *.ini

 

  進程Program配置分佈式

[program:usercenter]
directory = /home/leon/projects/usercenter ; 程序的啓動目錄
command = gunicorn -c gunicorn.py wsgi:app ; 啓動命令,能夠看出與手動在命令行啓動的命令是同樣的
autostart = true ; 在 supervisord 啓動的時候也自動啓動
startsecs = 5 ; 啓動 5 秒後沒有異常退出,就看成已經正常啓動了
autorestart = true ; 程序異常退出後自動重啓
startretries = 3 ; 啓動失敗自動重試次數,默認是 3
user = leon ; 用哪一個用戶啓動
redirect_stderr = true ; 把 stderr 重定向到 stdout,默認 false
stdout_logfile_maxbytes = 20MB ; stdout 日誌文件大小,默認 50MB
stdout_logfile_backups = 20 ; stdout 日誌文件備份數
; stdout 日誌文件,須要注意當指定目錄不存在時沒法正常啓動,因此須要手動建立目錄(supervisord 會自動建立日誌文件)
stdout_logfile = /data/logs/usercenter_stdout.log
; 能夠經過 environment 來添加須要的環境變量,一種常見的用法是修改 PYTHONPATH
; environment=PYTHONPATH=$PYTHONPATH:/path/to/somewhere

將進程配置添加到supervisord.conf文件中工具

推薦將各個進程配置放到單獨的文件中,而後經過[include]配置項引用post

[include]
files = /etc/supervisor/*.conf

supervisor服務啓動

運行命令

supervisord -c /etc/supervisord.conf

supervisor服務客戶端管理

 可使用supervisord的命令行客戶端管理工具supervisorctl來管理進程。

supervisorctl status
supervisorctl stop usercenter
supervisorctl start usercenter
supervisorctl restart usercenter
supervisorctl reread
supervisorctl update

 

supervisor web管理界面

;[inet_http_server] ; HTTP 服務器,提供 web 管理界面
;port=127.0.0.1:9001 ; Web 管理後臺運行的 IP 和端口,若是開放到公網,須要注意安全性
;username=user ; 登陸管理後臺的用戶名
;password=123 ; 登陸管理後臺的密碼

在瀏覽器中輸入http://127.0.0.1:9001,便可進入web管理界面

原文連接:https://www.chen-hao.com.cn/posts/6255/

相關文章
相關標籤/搜索