[系统运维]Supervisord安装和启动程序

supervisord

  • 是client/server 系统
  • 把不是守护进程的进程变成守护进程
  • 监控它自己启动的进程,类似于看门狗
  • 可以作为开机启动的一种封装
  • 可以精确控制进程的状态,而不是pidfile那么不准确


安装

说白了就是个Python包,官方文档,我这里系统是centos6.5 root用户

[python]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. pip install supervisor  

一般安装完的时候显示安装路径,如果不在bin路径,就自己添加一个软连接

配置文件在 /etc/supervisord.conf
我这里安装之后没有发现,我先到安装目录下找找,没有在自己创建那个文件,如果启动没有找
到就在启动命令中添加配置文件路径。


配置

supervisord 提供了一个模板文件,执行下面shell文件或者输出到文件中,改改就可以用了

[python]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. echo_supervisord_conf  
  2. #或者  
  3. echo_supervisord_conf > supervisord.conf  
不过模板文件有点太多了,我们还是按照文档写点程序来配置把,这次的目标是启动一个django开发

服务器并且让他成为一个独立进程,可以控制这个进程。

建立一个最简单的django,并可以启动

[python]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. [root@localhost ~]# pip install -i http://pypi.douban.com/simple django==1.6  
  2. [root@localhost ~]# su - lzz  
  3. [lzz@localhost ~]$ django-admin.py startproject lzztest  
  4. [lzz@localhost ~]$ cd lzztest/  
  5. [lzz@localhost lzztest]$ python manage.py runserver 8000 #看到可以正常启动,crtl+c关闭  
  6. [lzz@localhost lzztest]$ exit #切会到root用户下  

编辑supervisord文件 文件的内容如下 (有错误) ,文件的位置就是root的home路径 /root

[python]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. user=lzz  
  2. command=/usr/bin/python /home/lzz/lzztest/manage.py runserver 8000  
  3. autostart=true  
  4. autorestart=true  
  5. stderr_logfile=/home/lzz/lzztest/logs/err.log  
  6. stdout_logfile=/home/lzz/lzztest/logs/out.log  
  7. stopsignal=INT  

启动下观察效果,出现了一个错误。

[python]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. [root@localhost ~]# supervisord -c ./supervisord.conf   
  2. Error: .ini file does not include supervisord section  
  3. For help, use /usr/bin/supervisord -h  

意思是少了 [supervisrod] 配置项,可以参考 supervisord-section-settings, 修改配置文件如下,还有log文件最好先建立好,supervisord不会自己创建。

[python]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. [program:djangotest]  
  2. user=lzz  
  3. command=/usr/bin/python /home/lzz/lzztest/manage.py runserver 8000  
  4. autostart=true  
  5. autorestart=true  
  6. stderr_logfile=/home/lzz/lzztest/logs/err.log  
  7. stdout_logfile=/home/lzz/lzztest/logs/out.log  
  8. stopsignal=INT  
  9.    
  10. [supervisord]  

再次启动:

[python]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. [root@localhost ~]# supervisord -c /root/supervisord.conf  

正常启动了,我们来看下进程: ps -efH|grep python

<div class="linenums" style="margin: 0px; padding-left: 0px; color: rgb(30, 52, 123);"><div class="L0" style="margin: 0px; color: rgb(190, 190, 197); line-height: 18px; padding-left: 0px; list-style-type: none;"><code style="margin: 0px; padding: 0px; border: none; font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace; word-wrap: break-word; max-width: 100%; background-color: transparent;"><span class="pln" style="color: rgb(72, 72, 76); margin-top: 0px;">root     </span><span class="lit" style="color: rgb(25, 95, 145);">26253</span><span class="pln" style="color: rgb(72, 72, 76);">     </span><span class="lit" style="color: rgb(25, 95, 145);">1</span><span class="pln" style="color: rgb(72, 72, 76);">  </span><span class="lit" style="color: rgb(25, 95, 145);">0</span><span class="pln" style="color: rgb(72, 72, 76);"> </span><span class="lit" style="color: rgb(25, 95, 145);">02</span><span class="pun" style="color: rgb(147, 161, 161);">:</span><span class="lit" style="color: rgb(25, 95, 145);">57</span><span class="pln" style="color: rgb(72, 72, 76);"> </span><span class="pun" style="color: rgb(147, 161, 161);">?</span><span class="pln" style="color: rgb(72, 72, 76);">        </span><span class="lit" style="color: rgb(25, 95, 145);">00</span><span class="pun" style="color: rgb(147, 161, 161);">:</span><span class="lit" style="color: rgb(25, 95, 145);">00</span><span class="pun" style="color: rgb(147, 161, 161);">:</span><span class="lit" style="color: rgb(25, 95, 145);">00</span><span class="pln" style="color: rgb(72, 72, 76);">   </span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">usr</span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">bin</span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">python </span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">usr</span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">bin</span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">supervisord </span><span class="pun" style="color: rgb(147, 161, 161);">-</span><span class="pln" style="color: rgb(72, 72, 76);">c </span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">root</span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">supervisord</span><span class="pun" style="color: rgb(147, 161, 161);">.</span><span class="pln" style="color: rgb(72, 72, 76);">conf</span></code></div><div class="L1" style="margin: 0px; color: rgb(190, 190, 197); line-height: 18px; padding-left: 0px; list-style-type: none;"><code style="margin: 0px; padding: 0px; border: none; font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace; word-wrap: break-word; max-width: 100%; background-color: transparent;"><span class="pln" style="color: rgb(72, 72, 76); margin-top: 0px;">lzz      </span><span class="lit" style="color: rgb(25, 95, 145);">26254</span><span class="pln" style="color: rgb(72, 72, 76);"> </span><span class="lit" style="color: rgb(25, 95, 145);">26253</span><span class="pln" style="color: rgb(72, 72, 76);">  </span><span class="lit" style="color: rgb(25, 95, 145);">0</span><span class="pln" style="color: rgb(72, 72, 76);"> </span><span class="lit" style="color: rgb(25, 95, 145);">02</span><span class="pun" style="color: rgb(147, 161, 161);">:</span><span class="lit" style="color: rgb(25, 95, 145);">57</span><span class="pln" style="color: rgb(72, 72, 76);"> </span><span class="pun" style="color: rgb(147, 161, 161);">?</span><span class="pln" style="color: rgb(72, 72, 76);">        </span><span class="lit" style="color: rgb(25, 95, 145);">00</span><span class="pun" style="color: rgb(147, 161, 161);">:</span><span class="lit" style="color: rgb(25, 95, 145);">00</span><span class="pun" style="color: rgb(147, 161, 161);">:</span><span class="lit" style="color: rgb(25, 95, 145);">00</span><span class="pln" style="color: rgb(72, 72, 76);">     </span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">usr</span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">bin</span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">python </span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">home</span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">lzz</span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">lzztest</span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">manage</span><span class="pun" style="color: rgb(147, 161, 161);">.</span><span class="pln" style="color: rgb(72, 72, 76);">py runserver </span><span class="lit" style="color: rgb(25, 95, 145);">8000</span></code></div><div class="L2" style="margin: 0px; color: rgb(190, 190, 197); line-height: 18px; padding-left: 0px; list-style-type: none;"><code style="margin: 0px; padding: 0px; border: none; font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace; word-wrap: break-word; max-width: 100%; background-color: transparent;"><span class="pln" style="color: rgb(72, 72, 76); margin-top: 0px;">lzz      </span><span class="lit" style="color: rgb(25, 95, 145);">26255</span><span class="pln" style="color: rgb(72, 72, 76);"> </span><span class="lit" style="color: rgb(25, 95, 145);">26254</span><span class="pln" style="color: rgb(72, 72, 76);">  </span><span class="lit" style="color: rgb(25, 95, 145);">1</span><span class="pln" style="color: rgb(72, 72, 76);"> </span><span class="lit" style="color: rgb(25, 95, 145);">02</span><span class="pun" style="color: rgb(147, 161, 161);">:</span><span class="lit" style="color: rgb(25, 95, 145);">57</span><span class="pln" style="color: rgb(72, 72, 76);"> </span><span class="pun" style="color: rgb(147, 161, 161);">?</span><span class="pln" style="color: rgb(72, 72, 76);">        </span><span class="lit" style="color: rgb(25, 95, 145);">00</span><span class="pun" style="color: rgb(147, 161, 161);">:</span><span class="lit" style="color: rgb(25, 95, 145);">00</span><span class="pun" style="color: rgb(147, 161, 161);">:</span><span class="lit" style="color: rgb(25, 95, 145);">01</span><span class="pln" style="color: rgb(72, 72, 76);">       </span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">usr</span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">bin</span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">python </span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">home</span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">lzz</span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">lzztest</span><span class="pun" style="color: rgb(147, 161, 161);">/</span><span class="pln" style="color: rgb(72, 72, 76);">manage</span><span class="pun" style="color: rgb(147, 161, 161);">.</span><span class="pln" style="color: rgb(72, 72, 76);">py runserver </span><span class="lit" style="color: rgb(25, 95, 145);">8000</span></code></div></div>

终端关闭,重新打开别的终端可以看到进程正常。
实验基本成功,后面进程之间关系,怎么自动启动和停止被控制的程序等以后在深入研究下。

参考:



  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值