/3/xx/vgift/send
调用礼物系统 sendPresent
接口完成送礼, 以后写mongo,可是php error log 里却查不到任何mongo异常日志1是error log 丢日志了 2是程序执行过程当中操做完sendPresent后down掉了,致使没写入mongo -第一个状况工做多年的经验来看应该不至于,那就先根据第二种状况继续查吧php
[wu.daolin@web001.m6~]$ grep "2017 05:28" /var/log/php-fpm.log
[25-Jun-2017 05:28:01] NOTICE: Terminating ...
复制代码
php-fpm 是经过 php-fpm
这个命令进行管理的,咱们先看下这个命令linux
man php-fpm
这里有提到,php-fpm then responds to several POSIX signals
php-fpm 会对下面几个信号做(本身的)处理nginx
sudo kill -QUIT {php-fpm-pid}
[26-Jun-2017 13:58:22] NOTICE: Finishing ...
[26-Jun-2017 13:58:22] NOTICE: exiting, bye-bye!
复制代码
sudo kill -TERM {php-fpm-pid}
[26-Jun-2017 13:59:21] NOTICE: Terminating ...
[26-Jun-2017 13:59:21] NOTICE: exiting, bye-bye!
复制代码
sudo kill -USR2 12583
[26-Jun-2017 14:00:48] NOTICE: Reloading in progress ...
[26-Jun-2017 14:00:48] NOTICE: reloading: execvp("/usr/sbin/php-fpm", {"/usr/sbin/php-fpm", "--daemonize"})
[26-Jun-2017 14:00:48] NOTICE: using inherited socket fd=8, "10.30.60.87:9000"
[26-Jun-2017 14:00:48] NOTICE: using inherited socket fd=8, "10.30.60.87:9000"
[26-Jun-2017 14:00:48] NOTICE: fpm is running, pid 12696
[26-Jun-2017 14:00:48] NOTICE: ready to handle connections
复制代码
在 05:28:01
这个时间有人给php-fpm 发送了SIGTERM
信号,在这个点发生极可能是个定时任务, 确认果真是这样 28 5 * * * root /etc/init.d/php-fpm restart> /dev/null
git
killproc -p ${pidfile} php-fpm
, 显然从日志结果来个是kill -TERM
. 文档里也说了默认信号就是TERMkillproc sends signals to all processes that use the specified executable. If no signal name is specified, the signal SIGTERM is sent.
sendPresent
这个动做后 , 还没来得及写mongo库
, php-fpm就恰好被 terminate
了,.... 恰好遇上了terminate
跟 graceful stop
的具体含义, 但猜的话前者是直接就终止程序的执行了,后者多是温柔点,把处理中的请求里的全部操做都执行完再杀死。。。SIGTERM
terminate 调php 工做进程太粗暴了,应该要改一下比较好SIGUSER2
reload 方式SIGQUIT
方式 ,把killproc -p ${pidfile} php-fpm
这句 改为 killproc -p ${pidfile} php-fpm -QUIT
sa
的问答建议看下 -QUIT 时,Nginx的状态码是否正常?另外在某种状况下,可能会形成 PHP-FPM 进程退出时间比较长,会影响部署吗?github
用 reload(SIGUSER2)
而不是用SIGTERM
停掉再启动. 咱们以前的测试结果看 reload 以后,nginx会报 502,并不 graceful stop。建议作好测试确认,包括部署php代码时是否是 reload? Bug #60961 Graceful Restart (USR2) isn't very gracefulweb
php-fpm天天定时重启脚本 这个定时脚本大概是在2012年部署的,当时是担忧 PHP-FPM 存在内存泄漏的状况而添加的。到如今是否是还适用?建议找一台机器关掉定时脚本观察一段较长时间看看。缓存
SIGQUIT
是否正常还不清楚,但如今的默认 SIGTERM
是当即停掉php 进程是确定不正常的 -- 从nginx error log 看,对于nginx 和 php-fpm已经创建好的链接,错误是 “104: Connection reset by peer”; 准备去连的是“111: Connection refused”;bash
“111: Connection refused” 是还能够接受的,连不上而已,用户稍后重试就能够;“104: Connection reset by peer” 这个就很难接受,这个错我理解的意思是链接已经建好了,php忽然terminate了,而后发了个RST分节给nginx
;背后就表示当前请求可能只执行了一半动做,还有动做没执行完,这可能就形成丢数据了。。。好比文章开头说的这个问题socket
reload 那个其实就是 -USR2信号,这个bug看起来还没解决。。。不过-USR2 应该说是偶现terminate,但 -TERM 确定是必现terminatephp-fpm
如今代码部署逻辑是同步代码+清理opcache和yac缓存, 不对php-fpm进程作操做
php-fpm 会本身对worker进程处理的请求数计数,达到必定数量就干掉再从新拉一个; 因此worker进程应该没有什么内存泄露的问题; manager 进程就不清楚了,但我想几率应该是极其低的。这个适不适用感受很难去证伪啊。。。
因此要不找3台机器, 一台用 -QUIT, 一台用 -USR2, 一台去掉这个定时任务;先观察下
sa 回复能够,咱们本身看着办
104: Connection reset by peer
, 看来手册里说SIGQUIT: graceful stop
也不能保证一次请求里的全部动做都执行完啊去掉这个定时重启php-fpm 的任务
, 已经3个多月了,没发现问题,oh yeah~