Linux進程管理工具Supervisor詳解
Supervisor安裝與配置(linux/unix進程管理工具) Supervisor(http://supervisord.org)是用Python開發的一個client/server服務,是Linux/Unix系統下的一個進程管理工具,不支持Windows系統。它可以很方便的監聽、啟動、停止、重啟一個或多個進程。用Supervisor管理的進程,當一個進程意外被殺死,supervisort監聽到進程死后,會自動將它重新拉起,很方便的做到進程自動恢復的功能,不再需要自己寫shell腳本來控制。
因為Supervisor是Python開發的,安裝前先檢查一下系統否安裝了Python2.4以上版本。下面以CentOS7.6,Python2.7.5版本環境下,介紹Supervisor的安裝與配置步聚:
實驗環境
系統平臺
- cat /etc/redhat-release
- CentOSLinux release 7.6.1810(Core)
Python版本
- python -V
- Python2.7.5
如果python版本低于2.6請升級,下面貼出一個安裝python3.6.8的安裝示例
- yum install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel -y libffi-devel
- wget https://www.python.org/ftp/python/3.6.8/Python-3.6.8.tar.xz
- tar xf Python-3.6.8.tar.xz
- cd Python-3.6.8
- ./configure --prefix=/usr/local/python368
- make && make install
- echo 'export PATH=/usr/local/python368/bin:$PATH'>>/etc/profile
- source /etc/profile
- python3 -V
安裝 Supervisor
安裝 Supervisor的方法很多,以下介紹三種,我這里所采用的為第三種
1、easy_install 安裝 supervisor
安裝Python包管理工具(easy_install) easy_install是setuptools包里帶的一個命令,使用easy_install實際上是在調用setuptools來完成安裝模塊的工作,所以安裝setuptools即可:
- wget https://pypi.io/packages/source/s/setuptools/setuptools-33.1.1.zip
- unzip setuptools-33.1.1.zip
- cd setuptools-33.1.1
- python setup.py install
- easy_install supervisor
2、pip 安裝 supervisor
使用 pip 來安裝,前提要保證pip版本大于2.6
- pip install supervisor
3、yum epel-release 安裝 supervisor
- yum install -y epel-release && yum install -y supervisor
superviso命令
supervisor安裝完成后會生成三個執行程序:supervisortd、supervisorctl、echo_supervisord_conf:
•supervisortd:用于管理supervisor本身服務•supervisorctl:用于管理我們需要委托給superviso工具的服務•echo_supervisord_conf:用于生成superviso的配置文件•supervisor的守護進程服務(用于接收進程管理命令)•客戶端(用于和守護進程通信,發送管理進程的指令)
- [root@Jumpserver /]# which supervisord
- /bin/supervisord
- [root@Jumpserver /]# which supervisorctl
- /bin/supervisorctl
- [root@Jumpserver /]# which echo_supervisord_conf
- /bin/echo_supervisord_conf
配置Supervisor
通過運行echo_supervisord_conf程序生成supervisor的初始化配置文件
如果使用yum安裝則此步驟省略,直接進行修改配置文件步驟
- mkdir /etc/supervisord.d
- echo_supervisord_conf >/etc/supervisord.conf
修改配置文件
supervisor的配置文件內容有很多,不過好多都不需要修改就行使用,我這里只修改了以下兩項
- #修改socket文件的mode,默認是0700
- sed -i 's/;chmod=0700/chmod=0766/g'/etc/supervisord.conf
- #在配置文件最后添加以下兩行內容來包含/etc/supervisord目錄
- sed -i '$a [include] \
- files =/etc/supervisord.d/*.conf' /etc/supervisord.conf
編寫需要被Supervisor管理的進程
Supervisor只能管理非dameon進程,像默認的redis為前臺運行、Tomcat其實是 startup.sh shutdown.sh來調用catalina.sh進行后臺運行的,默認catalina.sh為前臺運行的程序,不能管理像Nginx一樣的非dameon進程
Tomcat被Supervisor管理
Tomcat安裝如下:
- wget http://us.mirrors.quenda.co/apache/tomcat/tomcat-8/v8.5.47/bin/apache-tomcat-8.5.47.tar.gz
- yum install java-1.8.0-openjdk.x86_64 java-1.8.0-openjdk-devel.x86_64 -y
- tar xf apache-tomcat-8.5.47.tar.gz -C /usr/local/
- mv /usr/local/apache-tomcat-8.5.47/usr/local/tomcat
想要我們的應用被Supervisor管理,就需要在/etc/supervisord目錄下編寫配置文件,Tomcat案例如下:
- vim /etc/supervisord.d/tomcat.conf
- [program:tomcat]#程序唯一名稱
- directory=/usr/local/tomcat #程序路徑
- command=/usr/local/tomcat/bin/catalina.sh run #運行程序的命令
- autostart=true#是否在supervisord啟動后tomcat也啟動
- startsecs=10#啟動10秒后沒有異常退出,就表示進程正常啟動了,默認為1秒
- autorestart=true#程序退出后自動重啟,可選值:[unexpected,true,false],默認為unexpected,表示進程意外殺死后才重啟;意思為如果不是supervisord來關閉的該進程則認為不正當關閉,supervisord會再次把該進程給啟動起來,只能使用該supervisorctl來進行關閉、啟動、重啟操作
- startretries=3#啟動失敗自動重試次數,默認是3
- user=root #用哪個用戶啟動進程,默認是root
- priority=999#進程啟動優先級,默認999,假如Supervisord需要管理多個進程,那么值小的優先啟動
- stopsignal=INT
- redirect_stderr=true#把stderr重定向到stdout標準輸出,默認false
- stdout_logfile_maxbytes=200MB#stdout標準輸出日志文件大小,日志文件大小到200M后則進行切割,切割后的日志文件會標示為catalina.out1,catalina.out2,catalina.out3...,默認50MB
- stdout_logfile_backups =100#stdout標準輸出日志文件備份數,保存100個200MB的日志文件,超過100個后老的將被刪除,默認為10保存10個
- stdout_logfile=/usr/local/tomcat/logs/catalina.out#標準日志輸出位置,如果輸出位置不存在則會啟動失敗
- stopasgroup=false#默認為false,進程被殺死時,是否向這個進程組發送stop信號,包括子進程
- killasgroup=false#默認為false,向進程組發送kill信號,包括子進程
啟動進程 使用supervisord管理啟動后,當你使用/usr/local/tomcat/shutdown.sh或者kill $PID的時候,supervisord都會認為是意外關閉,會自動再次把進程拉起,除非是使用supervisord命令關閉
- #supervisord啟動
- supervisord -c /etc/supervisord.conf #啟動supervisord進程,我們在配置文件中設置了 autostart=true 參數,在supervisord啟動的時候 tomcat也隨之啟動
- ps -ef|grep java #查看tomcat是否啟動
程序管理
- supervisorctl status tomcat #tomcat狀態
- supervisorctl stop tomcat #停止tomcat
- supervisorctl start tomcat #啟動tomcat
- supervisorctl restart tomcat #重啟tomcat
- supervisorctl reoload tomcat #重仔tomcat
Redis被Supervisor管理
redis默認不在配置文件中添加 daemonize yes 參數則是前臺啟動的,所以也可以被我們的的Supervisor所管理 redis配置文件如下:
- cat redis6001.conf
- port 6001
- bind 192.168.31.230
- protected-mode yes
- pidfile "/usr/local/redis/run/redis6001.pid"
- loglevel notice
- logfile "/usr/local/redis/logs/redis6001.log"
- save 9001
- stop-writes-on-bgsave-error yes
- rdbcompression yes
- rdbchecksum yes
- dbfilename dump.rdb
- dir "/usr/local/redis/data/rdb/"
- timeout 0
- tcp-keepalive 300
編寫redis被Supervisor管理的案例
- vim /etc/supervisord.d/redis.conf
- [program:redis]
- directory=/usr/local/redis
- command=/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis6001.conf
- autostart=true
- startsecs=10
- autorestart=true
- startretries=3
- user=root
- priority=999
- stopsignal=INT
- redirect_stderr=true
- stdout_logfile_maxbytes=200MB
- stdout_logfile_backups =100
- stdout_logfile=/usr/local/redis/logs/redis6001.log
- stopasgroup=false
- killasgroup=false
使用super啟動redis
- #關閉tomcat
- supervisorctl stop tomcat
- tomcat: stopped
- #殺掉supervisord
- ps -ef|grep supervisord
- root 269271010:47?00:00:00/usr/bin/python /bin/supervisord -c /etc/supervisord.conf
- root 2754927402011:07 pts/200:00:00 grep --color=autosuper
- kill -926927
- #重新啟動supervisord使其重新加載配置文件,supervisord默認會把redis和tomcat都拉起來
- supervisord -c /etc/supervisord.conf
程序管理
- supervisorctl status redis #redis狀態
- supervisorctl stop redis #停止redis
- supervisorctl start redis #啟動redis
- supervisorctl restart reids #重啟redis
- supervisorctl reoload redis #重載redis
程序管理
程序管理
- supervisorctl status all #查看所有進程狀態
- supervisorctl stop all #停止所有進程
- supervisorctl start all #啟動所有進程
- supervisorctl restart all #重啟所有進程
- supervisorctl reoload all #重載所有進程
Supervisord開啟啟動配置
- vim /usr/lib/systemd/system/supervisord.service
- [Unit]
- Description=ProcessMonitoringandControlDaemon
- After=rc-local.service nss-user-lookup.target
- [Service]
- Type=forking
- ExecStart=/usr/bin/supervisord -c /etc/supervisord.conf
- [Install]
- WantedBy=multi-user.target
- systemctl enable supervisord
- systemctl is-enabled supervisord