服务器 PHP 自动退出导致网站无法访问几分钟,给 Centos 安装 supervisor 进行进程守护。

服务器 PHP 自动退出导致网站无法访问几分钟,给 Centos 安装 supervisor 进行进程守护。


标签: ,

正在查看 2 个帖子:1-2 (共 2 个帖子)
  • 作者
    帖子
  • 诗语
    管理员
    • 文章数量: 5,865
    @feibisi
    楼主

    中午看到有客户下完单整个 http://www.weixiaoduo.com 网站就无法访问了,当时就是一脸懵逼,我还啥危险操作都没做呢,

    难道说是被人黑了?
    还是说服务器欠费宕机了?
    又或是安全软件执行什么操作导致的?
    再有是不是WordPress 哪个插件出了问题???
    ……

    一系列猜测花了差不多一分钟时间,然后赶紧先打开FTP 进服务器看了下,发现可以登录那么就是说服务器状态正常没欠费,然后试着把 WordPress 的插件目录改了下名称,但还是依旧 500 无法访问。

    再来有点儿着急了,因为我们站是实时都有客户访问的,上面问题测试完后,考虑要不要重启服务器,突然灵光一闪,是不是哪个服务给退出了??????

    然后赶紧进 SSH ,试着重启 Nginx 服务,然后再重启 PHP 服务,刷新网页,可以正常访问了。

    还真就是 PHP 给异常退出的缘故。这此几分钟无法访问,让我稍微有点儿措手不及,因为从去年更新服务器到现在还是头一回因为服务器软件退出导致的问题。

    那么还得想办法解决下,网上找了找发现有个 supervisor 可以进行特定进程的任务守护。

    楼下就简单贴下配置信息。

    诗语
    管理员
    • 文章数量: 5,865
    @feibisi
    楼主
    #安装setuptools
    yum install python-setuptools
    
    #安装supervisor
    easy_install supervisor
    
    #测试安装是否成功:
    echo_supervisord_conf
    #上面语句若输出配置文件信息表示安装成功
    
    #创建supervisor配置文件
    echo_supervisord_conf > /etc/supervisord.conf
    
    #修改配置文件:
    #在supervisord.conf最后增加:
    [program:php]
    command = php                   ;需要执行的命令
    autostart=true                   ;supervisor启动的时候是否随着同时启动
    autorestart=true               ;当程序跑出exit的时候,这个program会自动重启
    startsecs=1                    ;程序重启时候停留在runing状态的秒数
    startretries=3                   ;启动失败自动重试次数,默认是 3
    redirect_stderr=true           ;把 stderr 重定向到 stdout,默认 false
    stdout_logfile=/mnt/hgfs/htdocs/logs/stdout.log     ;stdout 日志文件
    stderr_logfile=/mnt/hgfs/htdocs/logs/stderr.log
    
    # 队列消费
    [program:queue_dispose]
    command                 = /usr/local/php/bin/php /alidata/www/artisan queue:work  --daemon --sleep=3 --tries=3
    process_name            = %(program_name)s_%(process_num)s
    numprocs                = 6 ;启动6个进程
    autostart               = true
    autorestart             = true
    stdout_logfile          = /alidata/log/php/supervisor_queue_dispose_out.log
    stdout_logfile_maxbytes = 10MB
    redirect_stderr=true
      
    [program:dsj_spider]
    command=/usr/local/php/bin/php  /mnt/hgfs/htdocs/www.test.com/index.php
    autostart=false
    autorestart=false
    startsecs=1                ;启动 1 秒后没有异常退出,就当作已经正常启动了
    startretries=3
    redirect_stderr=true
    stdout_logfile=/mnt/hgfs/htdocs/logs/stdout.log
    stderr_logfile=/mnt/hgfs/htdocs/logs/stderr.log
    
    #除以上将进程配置添加到supervisord.conf文件中
    #推荐将各个进程配置放到单独的文件中,然后通过[include]配置项引用
    [include]
    files = /etc/supervisor/*.conf
    
    #其他配置具体看/etc/supervisord.conf文件
    #supervisor服务启动
    supervisord -c /etc/supervisord.conf
    
    #supervisor服务客户端管理
    supervisorctl
    
    # 重新启动配置中的所有程序
    sudo supervisorctl reload 
    
    # 终止配置中的所有进程
    
    sudo supervisorctl stop all
    
    # 启动配置中的所有进程
    sudo supervisorctl start all

    亮点:web管理界面

    supervisor提供web管理页面,可以在网页端对进程进行监控,启动,终止,重启等操作

    将supervisord.conf中[inet_http_server]部分做相应配置,在supervisorctl中reload即可启动web管理界面

    [inet_http_server]           ; inet (TCP) server disabled by default
    port=192.168.10.129:9001     ; 外网ip(ip_address:port specifier, *:port for all iface)
    username=xxxxxxx             ; (default is no username (open server))
    password=xxxxxxx             ; (default is no password (open server))

    在浏览器打开网址192.168.10.129:9001,输入上面账号xxxxxxx密码xxxxxxx,即可进入web管理页面:

    注意:

    1、每次修改配置文件后需进入supervisorctl,执行reload, 改动部分才能生效

    2、Supervisor主要有两个命令:
    supervisord : 启动supervisor的服务器端
    supervisorctl:启动supervisor的命令行窗口,在该命令行中可执行start、stop、status、reload等操作。

    3、php脚本执行报’BACKOFF Exited too quickly (process log may have details)’错误解决:
    对于执行时间很短的php脚本,点击进程执行会报以上错误

    
    <?php
    require 'db.class.php';
    
    $dbHost = 'localhost';
    $dbUser = 'xxxxxx';
    $dbPasswd = 'xxxxxx';
    $dbName = 'test';
    
    $pdo = db::getInstance($dbHost, $dbUser, $dbPasswd, $dbName);
    
    $pdo->insert('test', ['name' => 'wml']);
    
    sleep(2);   #在php脚本最后一行加上一句,可解决该问题

    supervisor缺点:

    1. 单机监控
    2. 只能从supervisor启动的程序才能监控,从其他地方启动的无法监控
    可以使用阿里云监控 supervisord 进程, supervisord进程 监控各子进程

    其他监控工具如 monit ,功能更加强大。等以后研究

正在查看 2 个帖子:1-2 (共 2 个帖子)
  • 哎呀,回复话题必需登录。

未找到对应子版块?请直接在 [疑难杂症] 版块中发帖提问。

收藏纪念品


有奖活动

参与论坛社区问答,有机会获赠文派瓦普(Wapuu.com)手办模型。

话题信息

商业系统