首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Nginx+PHP(laravel) 环境 499 错误排查过程小记

前言 某公安项目过程中,在内网服务器部署 WNMP 环境,运行 Laravel 框架代码,后查看日志发现某一时刻突然所有请求 499,并持续一段时间,遂排查原因。...客户端主动关闭连接」 但某一时间段内全部请求均为返回 499,这显然不是所有客户端主动意识上的「关闭」,可能是因为客户端等待超时,自动关闭连接;加上 499 的时间段内包含部分 502,让我不得不怀疑: PHP...0x02 这里的死,不一定是进程结束,也有可能是僵尸,或是陷入死循环,一直在执行某个脚本…… 若是逐个检查代码时间来不及(以先解决问题为重),遂排查: Nginx+FastCGI 到底是谁影响超时时间...以及: PHP-max_execution_time 与 fpm.request_terminate_timeout 介绍 0x03 经过上面的调整,大约一周后再次维护服务器。...发现情况有所改善—— 499 错误已经由某一时段大量、集中出现变为偶尔发生,且只出现在某几个特定 URI 请求上。 我决定对这几个 URI 对应的接口控制器代码进行检查。

1.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    谈谈如何利用 valgrind 排查内存错误

    当时以为错误出现在 STL 库底层,且程序改动很小,便忽略了这个错误,熟不知底层的错误正是由于上层代码引起。后来在压测中发现程序频繁 crash,正是因为该错误导致。...其次,如果检查报告出现这类错误,那么千万不要忽略这个错误,一定要及时修复,及时止损。...最终不得已开启了 reachable 选项,让 Memcheck 报告出所有的 still reachable 信息,逐一排查这些可疑信息,终于定位了内存泄漏的点:原来是拉流缓存的数据包未在用户停止拉流后释放...后来,再次回顾这次解决内存泄漏的过程,发现逐一排查 still reachable 信息定位问题实在是效率低下,况且这次内存泄漏为何没有被报告出 definitely lost 错误?这是个问题。...所以这就是上文提到的问题:在某些场景下,still reachable 报错会掩盖掉 definitely lost 报错,从而加大内存泄漏问题的排查难度。

    7K41

    PHP与500错误

    PHP站点中一般是由PHP返回,也就是说,500错误一般都是PHP脚本的错误。...[php-fpm抓包500] 从上图中可以看出(Nginx+PHP-FPM架构),在PHP调用一个不存在的类时,脚本发生错误并返回500给Nginx(并且将错误信息也做了返回,只不过是卸载STDERR中...0x02、哪些错误异常会导致500 那么哪类错误会导致500错误呢,PHP所有的错误级别可以在PHP的官方文文档(http://php.net/manual/zh/errorfunc.constants.php...[E_ERROR级别错误导致的500] 0x03、什么情况下错误不会返回500 上面说了,这个是PHP脚本的错误导致的,但是PHP脚本有了错误或异常一定会导致500吗?...PHP自带错误日志 PHP本身已经带了错误日志的记录,可以在php.ini中将log_errors项设置为On,并配合error_log配置项来指定错误日志的存放路径。

    7.6K40

    PHP错误与异常

    图片 这篇文章基于PHP7 从PHP7起,PHP对异常做了较大改变,引入了Error,调整了继承结构Stringable这是个interface,只要能转字符串的类都应该实现这个接口Throwable能被...throw抛出的最基本的接口,但是PHP不允许直接实现这个接口Exception所有用户级异常的基类,想要自定义异常就可以继承这个LogicException代码逻辑错误,就是代码写的不对BadFunctionCallException...相当于编译期间的DomainExceptionUnderflowException空对象上的无效操作,eg: 删除元素UnexpectedValueException值不在可接受集合ErrorException错误异常...Error内部错误的基类TypeError类型不匹配ArgumentCountError参数数量不匹配ArithmeticError数学运算错误DivisionByZeroError除零错误AssertionError...断言失败错误CompileError编译错误ParseError解析PHP代码错误ValueError传值错误UnhandledMatchErrormatch未被匹配到任何分支FiberError在纤程上执行无效操作

    2.3K10

    php】关闭PHP错误提示方法,防止错误信息泄露

    关闭PHP错误提示方法,防止错误信息泄露 我们都知道,php代码有时候可能因为我们的一些操作失误,导致报错,然后会暴露错误信息。 为了防止错误信息泄露,需要关闭php错误提示。...方法一:修改PHP配置文件php.ini 首先打开配置文件php.ini 然后查找 ‘display_errors’,将display_errors = On 修改为 display_errors =...(Off为关闭错误提示,On为打开错误提示) 注意:如果你已经把PHP.ini文件复制到windows目录下,那么必须同时把c:windows/php.ini里的display_errors = On修改为...方法二:ini_set()函数 PHP ini_set用来设置php.ini的值,在函数执行的时候生效,脚本结束后,设置失效。无需打开php.ini文件,就能修改配置,对于虚拟空间来说,很方便。...(E_ALL^E_NOTICE^E_WARNING); 可以关闭所有notice 和 warning 级别的错误

    2K50

    Skywalking Php注册不上问题排查

    最近公司的一个Php应用在Skywalking后台查不到数据了: ? 登录到某台服务器上发现注册不上,启动时就报错了: ?...先来整理下Skywalking php的整个流程,php扩展在系统启动时注册应用和实例,然后在每次请求拦截相关调用,将相关调用情况保存下来;注册相关代码在skywalking.c的module_init...(E_WARNING, "skywalking: register service error"); return; } php_error(E_WARNING,...ipv4->set_value(ipv4s); language->set_key("language"); language->set_value("php...客户端已经没有线索了,只好从服务端入手,因为服务端是Java实现的,不大方便调试,因此在本地搭了个环境想调试下,哪知服务端跑起来了,Php客户端死活编译不上,因为Skywalking依赖protobuf

    2.2K10
    领券