一,安装问题及解决

  我这里习惯使用  easy_install supervisor 方式安装,以下的问题围绕这种安装方式。

  问题1, ImportError: No module named pkg_resources解决方案 

    这个问题通常是由于升级到python2.7后执行pip产生的解决方案是重新在python2.7环境中安装pip

  1.安装distribute

    wget https://pypi.python.org/packages/source/d/distribute/distribute-0.7.3.zip --no-check-certificate

    unzip distribute-0.7.3.zip

    cd distribute-0.7.3

    python setup.py install

  

  2.安装setuptool
     去这个地址 https://pypi.python.org/pypi/setuptools 下载最新版

     下载解压 并且python setup.py install

 

  3.安装pip

    easy_install pip

  

  4.安装pip的时候如果报错  ImportError: No module named extern异常 

    解决:在https://pypi.python.org/pypi/extern 下载最新extern安装后再次安装步骤pip.

二, 配置使用问题及解决

  1,生成配置文件 echo_supervisord_conf > /etc/supervisor/supervisord.conf  “这个路劲自己安排”

  2,修改配置文件 主要是下面几点

    (1)这个一般默认不用修改

        [unix_http_server]

        file=/tmp/supervisor.sock ; the path to the socket file    

      chmod=0700 ; socket file mode (default 0700)

    (2)这个一般默认不用修改

           [supervisord]
           logfile=/tmp/supervisord.log ; main log file; default $CWD/supervisord.log
           logfile_maxbytes=50MB ; max main logfile bytes b4 rotation; default 50MB
      logfile_backups=10 ; # of main logfile backups; 0 means none, default 10
      loglevel=info ; log level; default info; others: debug,warn,trace
      pidfile=/tmp/supervisord.pid ; supervisord pidfile; default supervisord.pid
      nodaemon=false ; start in foreground if true; default false
      minfds=1024 ; min. avail startup file descriptors; default 1024
      minprocs=200 ; min. avail process descriptors;default 200

     (3)   自定义配置文件的落脚点

      [include]     //一定要注意前面的分号 一点要去掉 不然这个模块没法加载  

      files = /etc/supervisor/conf.d/*.conf  //配置文件路径 相对、绝对路径都可以

   3,问题 Unlinking stale socket /XXXXX/XXXX/supervisor.sock   

       解决:unlink /XXXX/XXXXX/supervisor.sock 

   4,启动或者其他情况下出现  ImportError: cannot import name process_or_group_name 请见上面安装哪里

   5,出现  unix:///var/run/supervisor.sock no such file  可能是supervisor服务没有启动 

      解决:service  supervisor  start

   6,出现  error: <class ‘socket.error’>, [Errno 2] No such file or directory: file:/usr/lib/python2.7/socket.py line: 224   

      可能是supervisor服务没有启动  解决:service  supervisor  start

三,配置文件详解 

    [program:queue_worker]    ;项目名称
    directory = /www/tp5   ; 程序的启动目录
    command = php think queue:work --queue addData --daemon   ; 启动命令
    process_name=%(program_name)s_%(process_num)02d
    numprocs = 3   ; 开启的进程数量
    autostart = true    ; 在 supervisord 启动的时候也自动启动
    startsecs = 5   ; 启动 5 秒后没有异常退出,就当作已经正常启动了
    autorestart = true    ; 程序异常退出后自动重启
    startretries = 3   ; 启动失败自动重试次数,默认是 3
    user = www   ; 用哪个用户启动
    redirect_stderr = true   ; 把 stderr 重定向到 stdout,默认 false
    stdout_logfile_maxbytes = 50MB    ; stdout 日志文件大小,默认 50MB
    stdout_logfile_backups = 20   ; stdout 日志文件备份数、

    loglevel = info   ;记录等级 有critical, error, warn, info, debug, trace, or blather等

    ; stdout 日志文件,需要手动创建目录(supervisord 会自动创建日志文件)

    stdout_logfile = /www/supervisor/log/queue_worker.log

 四,其他注意

  1,修改了Supervisor 的配置信息后,必须执行下面命令

     sudo supervisorctl reload

     sudo supervisorctl update

  2,个人猜想

    在ubuntu和centos中开启一个项目 直接是  supervisorctl start name, 但是在Redhat中需要  supervisorctl start name:*  这是我遇到的问题。

***转载请务必注明来源 谢谢

11-29 16:08