1.安装:
a. wget方式 (对python版本要求比较严格。)
cd /usr/local/lee #这个lee是我自己建立的一个目录
wget https://pypi.python.org/packages/7b/17/88adf8cb25f80e2bc0d18e094fcd7ab300632ea00b601cbbbb84c2419eae/supervisor-3.3.2.tar.gz
tar -zxvf supervisor-3.3.2.tar.gz
cd supervisor-3.3.2
python setup.py install
b. yum 方式安装
yum install python-setuptools
easy_install supervisor
#如果第一次未安装成功,需要 跟新下yum 资源 yum update
安装完成后 可以 supervisord -h 查看是否安装成功
2.配置
安装成功后,可能没有配置文件,需要自己手动生成
mkdir /etc/supervisor
echo_supervisord_conf > /etc/supervisord.conf
vim /etc/supervisord.conf
将底部的
;[include]
;files = relative/directory/*.ini
修改为:
[include]
files=/etc/supervisor/*.conf
(注意去掉分号,第一次安装的时候就因为没去掉分号出现了问题!)
问题:
- 我在echo_supervisord_conf 的时候 提示我 版本不对 meld3 >= 0.6.5
Meld到底是个什么东西呢,meld主要是一个可视化的比较和合并的工具,目标人群是开发者(当然,我们将要讲到的其它部分也会考虑到最终用户)。这个工具同时支持双向和三向的比较,不仅仅是比较文件,还可以比较目录,以及版本控制的项目。Meld可以帮你回顾代码改动,理解补丁,”其官网如是说。“它甚至可以告知你如果你不进行合并将会发生什么事情。该工具使用 GPL v2 协议进行授权。
升级meld
#下载meld
sudo wget https://pypi.python.org/packages/45/a0/317c6422b26c12fe0161e936fc35f36552069ba8e6f7ecbd99bbffe32a5f/meld3-1.0.2.tar.gz#md5=3ccc78cd79cffd63a751ad7684c02c91
sudo tar zxvf meld3-1.0.2.tar.gz
cd meld3-1.0.2
sudo python setup.py install
sudo ldconfig
#再次执行生成配置文件成功:
sudo /usr/bin/echo_supervisord_conf
vim /etc/supervisor/test.conf
#写入一些配置:
[program:test] # 设置进程的名称,使用 supervisorctl 来管理进程时需要使用该进程名 我这里就叫做test了!
command=php think queue:work --queue saveLoginLog --daemon --tries 10; #这个就是队列执行的命令
directory= /www/wwwroot/admin; #命令执行的目录或者说执行 command 之前,先切换到工作目录 可以理解为在执行命令前会切换到这个目录
process_name=%(process_num)02d; #默认为 %(program_name)s,即 [program:x] 中的 x 这个是进程名,如果我们下面的numprocs参数为1的话,就不用管这个参数
了,它默认值%(program_name)s也就是上面的那个program冒号后面的
numprocs=5; #进程数量当不为1时的时候,就是进程池的概念,注意process_name的设置
autostart=true; #是否自动启动
autorestart=true; #程序意外退出是否自动重启
startsecs=1; 自动重启间隔
startretries=20; 当进程启动失败后,最大尝试启动的次数。。当超过3次后,supervisor将把此进程的状态置为FAIL 默认值为3 。。
redirect_stderr=true; 如果为true,则stderr的日志会被写入stdout日志文件中 理解为重定向输出的日志
user=root; 这个参数可以设置一个非root用户,当我们以root用户启动supervisord之后。我这里面设置的这个用户,也可以对supervisord进行管理
stdout_logfile= /www/wwwroot/admin/test.out.log; 子进程的stdout的日志路径 输出日志文件
stderr_logfile=/www/wwwroot/admin/test.err.log ; 错误日志文件 当redirect_stderr=true。这个就不用
#没有注释的
[program:test]
command=php think queue:work --queue saveLoginLog --daemon --tries 10
directory= /www/wwwroot/admin
process_name=%(process_num)02d
numprocs=5
autostart=true
autorestart=true
startsecs=1
startretries=20
redirect_stderr=true
user=root
stdout_logfile= /www/wwwroot/admin/test.out.log
stderr_logfile=/www/wwwroot/admin/test.err.log
3.加载配置文件,重载
supervisord -c /etc/supervisord.conf
supervisorctl reload
问题:
2. 在加载配置文件的时候,可能会报错: Another program is already listening on a port that one of our HTTP servers is configured to
find / -name supervisor.sock
unlink /name/supervisor.sock
# 不过一般是在 /tmp/supervisor.sock 可以在配置文件查看
- 启动 管家服务 (监听)
supervisorctl update
- 停止 管家服务
supervisorctl stop all
supervisorctl stop test(服务名称)
补充:
- 如果需要管理的程序教多,我们可以进行分组, supervisor提供了一个group功能
[group:misc]
programs=test,foo,bar
重启之后就可以用下面的命令控制了
# 重启misc组的所有进程
supervisorctl restart misc:*
# 停止misc组的test进程
supervisorctl stop misc:test
# 启动所有进程
supervisorctl start all
- 命令解释:
supervisorctl #启动client端
supervisorctl update #更新client
supervisorctl status # 查看客户端状态
supervisorctl tail -f test # 运行测试文件
3.http server web界面管理后台
supervisor还自带了一个web界面的管理后台,要启用它,需要打开配置文件,修改以下几行
[inet_http_server]
port=127.0.0.1:9001
username=user
password=123
supervisorctl reload # 执行命令
这样就启用了内置的管理后台,然后在浏览器内输入http://127.0.0.1:9001,输入用户名密码后就可以看到管理后台的界面。