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

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

标签: ,

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

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

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

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

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

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

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

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

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

    诗语
    管理员
    • 文章数量: 5,908
    @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 个帖子)
  • 哎呀,回复话题必需登录。

话题信息