设为首页 收藏本站
查看: 760|回复: 0

[经验分享] 一个关于nginx网关504的问题

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-2-2 08:56:02 | 显示全部楼层 |阅读模式
我们线上web环境比较简单,web服务器采用的是淘宝开源的tengine,开发语言则采用php,并启用php-fpm的监听。    事情要从1月29号下午说起,当时一个同事为给php添加多线程模块pthread,将线上php重新编译,结果编译完成后,前端web无法正常访问,页面一直报504错误。一时找不到解决办法,于是将php临时切换到备用php环境上,然后我在原来环境中按照以前的参数重新编译php,配置文件则直接使用原php配置文件,并于晚上10点30左右,将php从备用环境切回到我重新编译后的php环境中,并测试正常。此为前提。
    1月30号早上,我在来公司的路上,还通过手机访问网站,确认新的php环境不会再出现504问题。但一到公司,并听到开发同事惊呼,网站又宕了,又是昨天的504错误。于是我检查环境,环境没有问题,在找不到办法的情况下,我重启php-fpm,然后网站恢复正常,2分钟之后,同事又开始反映网站无法访问,错误依然是504,于是我又重启php-fpm,如是再三,总是一重启就正常,隔2分钟就又开始报504。为了不影响线上业务,我重新将php切换到备用环境,然后开始排查问题根源。
    既然最初504的问题起始于昨天下午同事重新编译php之后,那么该问题当于php有关,我查询php-fpm错误日志,找到如下信息:
[30-Jan-2015 09:30:12] WARNING: [pool www] server reached pm.max_children setting (5), consider raising it
[30-Jan-2015 09:30:45] WARNING: [pool www] server reached pm.max_children setting (5), consider raising it
[30-Jan-2015 09:31:05] WARNING: [pool www] server reached pm.max_children setting (5), consider raising it
[30-Jan-2015 09:31:18] WARNING: [pool www] server reached pm.max_children setting (5), consider raising it
[30-Jan-2015 09:31:26] WARNING: [pool www] server reached pm.max_children setting (5), consider raising it
[30-Jan-2015 09:31:39] WARNING: [pool www] server reached pm.max_children setting (5), consider raising it
根据提示,是因为php最大子进程数达到了上限,无法再接入新的请求,而允许的最大子进程数居然只有5。看到这个结果,我很奇怪,这是没有可能的。因为配置文件没有任何修改,直接copy的原配置文件。不管如何,先确认配置文件,果然,进程相关的配置项如下:
pm = dynamic
pm.max_children = 5
pm.start_servers = 2
pm.min_spare_servers = 1
pm.max_spare_servers = 3
为什么会这样?
我与昨天下午重新编译php的同事沟通,发现他在重新编译时,虽然将配置文件事先做了备份,但他在编译完成后,并未将备份的配置文件覆盖回来。换而言之,我从原配置环境中复制的配置文件是他重新编译php后生成的默认配置文件。这真是坑爹。当我重新找到他之前的备份文件,并将其恢复到新环境之后,网站终于恢复正常。

这次事件,并不是因为很复杂隐蔽的问题造成。但却造成了很严重的后果。而这次事件的根本原因还是团队的沟通问题以及个人的细心问题。如果同事在更新环境之前先行与我们沟通,不会导致编译参数出错的问题,如果他告诉我配置文件没有还原回去,我也不会去用那个默认配置文件。而如果我稍微细心一点,在复制配置文件的时候,做一下检查,也不会出现问题。
说到底,运维的工作还是要沟通与谨慎,希望以后不会再出现这样的问题。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-41823-1-1.html 上篇帖子: Nginx + tomcat + keepalived 负载均衡 下篇帖子: http status 413 (Request Entity Too Large)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表