php执行后报502,无错误提示的排查和解决

文章目录

  • 一、阐述问题
  • 二、开始排查
    • 1.执行代码展示
    • 2.PHP层面排查问题
    • 3.系统层面排查问题
      • 1. 分析系统日志
      • 2. core dump 分析
        • 2.1 core dump 是什么
        • 2.2 core dump 配置 并 生成 core 文件
        • 2.3 gdb 解析 core 文件
    • 4. 问题解决
  • 三、赠送内容
  • 四、总结

一、阐述问题

这个问题花了我起码10个小时,必须得总结一下。

问题是这样的,我在laravel 里面连接了一下sqlserver的数据库,然后页面直接就报502。去项目下的日志看,也没有任何报错。

二、开始排查

1.执行代码展示

$serverName = '192.168.116.180\messyna'; //数据库服务器地址
$connectionInfo = array("UID" => "mssa", "PWD" => "12345677", "Database" => 'test111');
$conn = sqlsrv_connect($serverName, $connectionInfo);
if($conn == FALSE){echo "连接失败!";var_dump(sqlsrv_errors());exit;
}else{echo "链接成功";
}
echo "连接成功!";
exit;

这就是普通的连接sqlserver的代码。只要执行这段代码,直接就报 502!

Sqlserver的配置肯定没问题,前一天还是可以执行的。而且有其他的机器能执行。

2.PHP层面排查问题

经过一段时间的乱碰,觉得还是看一下php-fpm的错误日志。

找到php-fpm的配置,找到错误日志路径。

在这里插入图片描述

终于看到报错信息:
在这里插入图片描述
deepseek的回答结果如下:

WARNING: [pool www] child 4542 exited on signal 11 (SIGSEGV) after 542.345727 seconds from start

  • 含义:www 进程池中的子进程 4542 在运行 542秒(约9分钟) 后,因 信号 11(SIGSEGV) 崩溃退出。

    • SIGSEGV(分段错误):表示进程试图访问非法内存地址,常见原因包括:

      • PHP 扩展(如 Redis、Opcache 等)存在 bug。

      • PHP 代码中存在内存溢出(如无限递归、大数组操作)。

      • 服务器内存不足或配置错误(如 pm.max_children 设置过高)。

      • 硬件问题(如内存条故障,但概率较低)。

我的分析测试:

  1. 硬件问题 可以排除,最近我都没动过什么配置之类的。而且是虚拟主机,不可能。
  2. PHP 代码中存在内存溢出 可以排除。就一个连接,能有什么溢出
  3. 内存不足 ,我将虚拟主机加大了2G内存, 结果还是502,说明不是内存问题。
  4. 扩展问题 ,感觉有点像
    - mysql的连接是正常的,就sqlserver 不正常
    - 重新安装 pdo_sqlsrv 和 sqlsrv 两个扩展,结果依然是502,跟扩展没关系
  5. 重装php8.2 ,结果测试,还是502

经过以上的测试,差不多可以知道,应该不是php的问题。应该是centos系统的问题。不管怎么测试。指向的都是 分段错误

3.系统层面排查问题

1. 分析系统日志

dmesg | grep php 在系统日志中筛选与 “php” 相关的信息

在这里插入图片描述

取一条日志出来看看:

[65062.298372] php-fpm[1288]: segfault at 0 ip 00007fc555571fd6 sp 00007fff26f52bb8 error 4 in libc-2.17.so[7fc555433000+1c4000]

经过查资料分析:

这个错误提示表明 PHP-FPM 进程发生了段错误(segfault),这通常是由内存访问违规引起的严重错误。

segfault at 0:程序尝试访问内存地址 0x0(空指针),这通常是由于未初始化的指针或内存损坏导致的。

libc-2.17.so:错误发生在 C 标准库中,这是系统核心组件,可能由以下原因触发:

  • PHP 扩展与 libc 不兼容。
  • PHP 本身存在内存管理漏洞。
  • 系统库文件损坏。

error 4:表示 SEGV_ACCERR(访问权限错误),即程序尝试访问没有权限的内存区域。

总体上来说,应该是读取内存地址无效。但是没有具体的信息,过于笼统,还需要进一步的调试。

又经过了漫长的查资料,终于查到了一点方向,core dump

2. core dump 分析

2.1 core dump 是什么
  1. core dump 是什么?
    core dump(核心转储) 是操作系统在程序异常终止(如崩溃、段错误、非法指令等)时,将进程当时的内存状态、寄存器内容、程序计数器值等关键信息写入到一个文件中的过程。这个文件被称为 core 文件,它本质上是进程运行时状态的 “快照”。

  2. core dump 的作用

    • 调试程序错误
      开发人员可以通过分析 core 文件,定位程序崩溃的具体位置(如哪行代码引发错误)、变量值、函数调用栈等信息,从而快速排查内存越界、空指针引用、段错误等问题。

    • 系统故障分析
      在服务器环境中,core dump 可用于分析长期运行的服务(如 Web 服务器、数据库)突然崩溃的原因,避免问题反复出现。

    • 性能优化参考
      虽然 core dump 主要用于错误定位,但也能间接反映程序的内存使用模式,为性能优化提供线索。

  3. core dump 的触发场景
    当程序遇到以下情况时,系统通常会生成 core dump:

    • 访问非法内存地址(如空指针解引用、数组越界)
    • 执行非法指令(如除以 0、无效的 CPU 操作码)
    • 收到无法处理的信号(如 SIGSEGV、SIGABRT)
    • 内存不足或被系统强制终止(如 OOM Killer 触发)

正和我意,触发场景正好能解决我的问题。

2.2 core dump 配置 并 生成 core 文件
  1. 设置 core 文件大小为无限制(unlimited):

    //临时调试
    ulimit -c unlimited//调试完最后记得关闭 core dump
    ulimit -c 0
    
  2. 执行 php 代码,报错 502。 此时在项目的根目录下,会生成一个 core 文件。

    在这里插入图片描述

这几个core 文件就记录了 内存读取失败的相关情况,那接下来就是读取这个core 文件了

2.3 gdb 解析 core 文件

GDB(GNU Debugger) 是 Linux/Unix 系统下最常用的 代码调试工具,主要用于分析和修复程序崩溃、死锁、内存泄漏等问题

1. 安装 gdb

yum install gdb

2. 生成 GDB 回溯信息

gdb php core.2134
(gdb) bt full  # 获取完整的堆栈回溯

3. 文件内容如下:

在这里插入图片描述

4. 经过deepseek分析:

在这里插入图片描述

4. 问题解决

根据 GDB 完整堆栈回溯信息,问题的根源已经很明显了

OpenSSL库版本冲突 ,有两个库版本,ODBC驱动尝试初始化SSL连接时,不同版本的OpenSSL库发生冲突,导致内存访问异常

在这里插入图片描述

确实是有两个,而且那个还是前一天我安装 python 时候产生的。

直接删除openssl111,因为openssl111 安装前,一直是正常的。肯定是 openssl111 安装了,导致出问题

删除后,执行代码,一切正常。终于解决

三、赠送内容

以下是监控 PHP-FPM 主进程,然后程序崩溃时,可以查看具体情况

 # 附加到 PHP-FPM 主进程
sudo gdb -p $(pgrep -o php-fpm)# 当崩溃发生时,输入以下命令抓取堆栈
(gdb) bt full             # 查看完整调用栈
(gdb) info threads        # 查看所有线程状态
(gdb) quit                # 退出

四、总结

整个过程非常艰辛,由什么问题都不知道一直到解决,查了很多资料。走了很多的弯路。

一些工具都是第一次使, core dump,gdb 以前基本上没使用过。

需要持续的学习,持续的踩坑,才能到达最终的彼岸 =》保安

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/diannao/86058.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL 核心知识点解析

最近正在复习Java八股,所以会将一些热门的八股问题,结合ai与自身理解写成博客便于记忆 InnoDB 和 MyISAM 的区别 特性InnoDBMyISAM事务支持支持ACID事务不支持事务锁机制行级锁表级锁外键支持支持不支持崩溃恢复有crash-safe能力无存储结构聚簇索引非…

CppCon 2015 学习:Comparison is not simple, but it can be simpler.

What is comparison? 这段文字是从计算机科学、编译器设计或系统优化的角度来定义和评价“比较(comparison)”这个操作: 1. Pervasive(无处不在) 比较操作在编程中极为常见,存在于: 分支语句&…

RocketMQ入门5.3.2版本(基于java、SpringBoot操作)

一、RocketMQ概述 RocketMQ是一款由阿里巴巴于2012年开源的分布式消息中间件,旨在提供高吞吐量、高可靠性的消息传递服务。主要特点有: 灵活的可扩展性 海量消息堆积能力 支持顺序消息 支持多种消息过滤方式 支持事务消息 支持回溯消费 支持延时消…

VR线上展厅特点分析与优势

VR线上展厅:特点、优势与实际应用 VR线上展厅,作为虚拟现实(VR)技术在展示行业的创新应用,正逐步改变着传统的展览方式。通过模拟真实的物理环境,为参观者提供身临其境的展览体验,成为展示行业…

QT 5.9.2+VTK8.0实现等高线绘制

项目下载链接:QT5.9.2VTK8.0实现等高线绘制资源-CSDN文库 示例如下: 主要代码如下: #include "vtkRenderer.h" #include "vtkRenderWindow.h" #include "vtkRenderWindowInteractor.h" #include "vtkPo…

MySQL:忘记root密码

修改配置文件: vi /etc/my.cnf## 修改配置文件 ##[mysqld] skip - grant - tables## 重启 ##/etc/init.d/mysqld restart ## 或service mysqld restart## 登录mysqld -u root -p -h 127.0.0.1USE mysql; UPDATE user SET Password password(123456) WHERE User r…

JSP、HTML和Tomcat

9x9上三角乘法表 乘法表的实现 <% page contentType"text/html;charsetUTF-8" language"java" %> <!DOCTYPE html> <html> <head><title>99 上三角乘法表</title><style>body {font-family: monospace;padding…

常用枚举技巧:基础(一)

文章目录 常用枚举技巧&#xff1a;基础&#xff08;一&#xff09;LeetCode 1. 两数之和思路Golang 代码 LeetCode 2441. 与对应负数同时存在的最大正整数思路Golang 代码 LeetCode 1512. 好数对的数目思路Golang 代码 LeetCode 2001. 可互换矩形的对数思路Golang 代码 LeetCo…

从混乱到秩序:探索管理系统如何彻底改变工作流程

内容摘要 在许多企业与组织中&#xff0c;工作流程混乱是阻碍发展的“绊脚石”。员工们常常被繁琐的步骤、模糊的职责和沟通不畅等问题搞得焦头烂额&#xff0c;工作效率低下&#xff0c;错误频发。而与之形成鲜明对比的是&#xff0c;一些引入了先进管理系统的团队&#xff0…

使用SSE解决获取状态不一致问题

使用SSE解决获取状态不一致问题 1. 问题描述2. SSE介绍2.1 SSE 的工作原理2.2 SSE 的事件格式规范2.3 SSE与其他技术对比2.4 SSE 的优缺点 3. 实战代码 1. 问题描述 目前做的一个功能是上传多个文件&#xff0c;这个上传文件是整体功能的一部分&#xff0c;文件在上传的过程中…

华为×小鹏战略合作:破局智能驾驶深水区的商业逻辑深度解析

当中国智能电动车竞争进入下半场&#xff0c;头部玩家的合纵连横正在重构产业格局。华为与小鹏汽车近日官宣的“战略合作”&#xff0c;表面看是技术互补的常规操作&#xff0c;实则暗藏改写行业游戏规则的深层商业逻辑。 一、技术破壁&#xff1a;从“单点突破”到“全栈协同”…

Tailwind CSS 实战:基于 Kooboo 构建 AI 对话框页面(六):图片上传交互功能

在 《Tailwind CSS 实战&#xff1a;基于 Kooboo 构建 AI 对话框页面&#xff08;五&#xff09;》 中&#xff0c;完成了语音交互功能的优化。本文作为该系列教程的第六篇&#xff0c;将聚焦于图片上传功能的开发。通过集成图片上传与预览能力&#xff0c;我们将进一步完善 AI…

40. 自动化异步测试开发之编写异步业务函数、测试函数和测试类(类写法)

40. 自动化异步测试开发之编写异步业务函数、测试函数和测试类&#xff08;类写法&#xff09; 一、类结构设计解析 1.1 基类设计 class Base:async_driver None # &#x1f697; 存储浏览器驱动实例async def get(self, url: str http://secure.smartbearsoftware.com/.…

面向开发者的提示词工程④——文本推断(Inferring)

文章目录 前言一、情感&#xff08;正向/负向&#xff09;二、识别情感类型三、识别愤怒四、从客户评论中提取产品和公司名称五、一次完成多项任务 前言 面向开发者的提示词工程——导读 在这节课中&#xff0c;你将从产品评论和新闻文章中推断情感和主题。 举了个商品评论的例…

java day15 (数据库)

进入数据库的学习 DB 因为数据太多了&#xff0c;方便统一管理的软件 操作就不用改代码了&#xff0c;直接改数据库则可&#xff1b; 命令就是sql语句 这些都是关系型数据库&#xff0c;sql可以控制全部&#xff0c;至于具体的环境我以前就有安装过了&#xff1b; 理解&am…

国标GB28181设备管理软件EasyGBS远程视频监控方案助力高效安全运营

一、方案背景​ 在商业快速扩张的背景下&#xff0c;连锁店门店数量激增&#xff0c;分布范围广。但传统人工巡检、电话汇报等管理方式效率低下&#xff0c;存在信息滞后、管理盲区&#xff0c;难以掌握店铺运营情况&#xff0c;影响企业效率与安全。网络远程视频监控系统可有…

Python 字典(dict)的高级用法与技巧

今天我们继续深入讲解 Python 字典的 高级用法与技巧&#xff0c;包括&#xff1a; defaultdict&#xff1a;带默认值的字典Counter&#xff1a;快速统计工具字典排序&#xff1a;按键或值排序合并字典&#xff08;传统方式和 Python 3.9 新语法&#xff09;嵌套字典的安全访问…

动静态库的使用(Linux)

1.库 通俗来说&#xff0c;库就是现有的&#xff0c;可复用的代码&#xff0c;例如&#xff1a;在C/C语言编译时&#xff0c;就需要依赖相关的C/C标准库。本质上来说库是一种可执行代码的二进制形式&#xff0c;可以被操作系统载入内存执行。通常我们可以在windows下看到一些后…

R²ec: 构建具有推理能力的大型推荐模型,显著提示推荐系统性能!!

摘要&#xff1a;大型推荐模型通过编码或项目生成将大型语言模型&#xff08;LLMs&#xff09;扩展为强大的推荐工具&#xff0c;而近期在LLM推理方面的突破也同步激发了在推荐领域探索推理的动机。目前的研究通常将LLMs定位为外部推理模块&#xff0c;以提供辅助性思考来增强传…

【Java后端基础 005】ThreadLocal-线程数据共享和安全

&#x1f4da;博客主页&#xff1a;代码探秘者 ✨专栏&#xff1a;文章正在持续更新ing… ✅C语言/C&#xff1a;C&#xff08;详细版&#xff09; 数据结构&#xff09; 十大排序算法 ✅Java基础&#xff1a;JavaSE基础 面向对象大合集 JavaSE进阶 Java版数据结构JDK新特性…