php進程的SIGBUS故障

来源:http://www.cnblogs.com/chenpingzhao/archive/2016/06/06/5563605.html
-Advertisement-
Play Games

某個子站是php寫的,訪問的時候nginx時不時會冒出現502錯誤,高峰時更頻繁,檢查php-fpm的日誌發現大量的 child exited on signal 7 (SIGBUS),並且和accesslog里的502時間完全吻合,排除了php進程過載的可能,然後又排除了apc的嫌疑。 既然php ...


某個子站是php寫的,訪問的時候nginx時不時會冒出現502錯誤,高峰時更頻繁,檢查php-fpm的日誌發現大量的 child exited on signal 7 (SIGBUS),並且和accesslog里的502時間完全吻合,排除了php進程過載的可能,然後又排除了apc的嫌疑。

既然php進程是收到信號後死亡的,那麼嘗試抓些coredump來分析吧:

先設置一下coredump的保存路徑,註意要空間夠大的地方,因為coredump可能會較多而且很大(比如開了apc設置了1G,那就會有1G):

#echo "/tmp/core.%e.%p.%h.%t" > /proc/sys/kernel/core_pattern

然後修改下ulimit,允許coredump:

#ulimit -c unlimited

重啟php-fpm。 要不了多久,/tmp/目錄里就產生了一堆coredump文件,很好,打包拖回線下來分析吧。 記得關閉coredump,並重啟程式:

#ulimit -c 0

分析coredump一般用gdb就夠了,(二進位發行版的話,先安裝對應的debug symbol包):

gdb /usr/local/php/sbin/php-fpm core.php-fpm.10375.php.1365314990

執行下bt命令,看下backtrace(具體的信息忘記記錄了),發現是掛在lex_scan函數,看了好幾個coredump,基本都是掛在lex階段的函數。

我對php源碼沒什麼研究,上google搜一下“php sigbus lex_scan”,前兩名的連接基本就給出了答案:

2010年報的bug,一直沒有close,因為看起來這並不是php的bug,仔細看,裡面有重現的範例,最後也有人找到了規避辦法。

此君經歷了和我一樣的分析過程,並且給出了明確的原因和解決辦法。

簡單說lex_scan是在對php文件進行語法分析,這個時候正好一個包含的php文件被改寫,於是悲劇發生。

為了證實,我用strace跟蹤php進程的執行,最後終於抓到了:

11670 lstat("/home", {st_mode=S_IFDIR|0755, st_size=4096, ...}) = 0

11670 stat("/home/www/cache/default.php", {st_mode=S_IFREG|0644, st_size=68579, ...}) = 0

11670 --- SIGBUS (Bus error) @ 0 (0)

 

 

來源:http://blog.druggo.org/post/2013/05/02/%E4%B8%80%E4%BE%8Bphp%E8%BF%9B%E7%A8%8B%E7%9A%84SIGBUS%E6%95%85%E9%9A%9C


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一. 安裝ant 1. 解壓apache-ant-1.9.4-bin到任意地方 2. 配置環境變數ANT_HOME為apache-ant-1.9.4-bin解壓後的目錄地址,如D:\Download\apache-ant-1.9.4 3. 在環境變數CLASSPATH中加入%ANT_HOME%\li ...
  • 通過註解的方式實現一個簡單的HelloWorld。 一、新建項目 同SpringMVC_HelloWorld_01 二、配置文件 1、配置web.xml 2、配置springmvc-servlet.xml 三、編寫Controller 四、新建jsp頁面 同SpringMVC_HelloWorld_ ...
  • XML是一種可擴展標記語言,它被設計用來傳輸和存儲數據。XML是各種應用程式之間進行數據傳輸的最常用的工具。它與Access,Oracle和SQL Server等資料庫不同,資料庫提供了更強有力的數據存儲和分析能力,例如:數據索引、排序、查找、相關一致性等,它僅僅是**存儲數據**。事實上它與其他數... ...
  • 知識點: 介紹Maven 本機搭建Maven環境 DEMO測試 本地倉庫遷出 Maven簡介: 百度百科: 說到底就是一個項目管理工具。 本機搭建Maven環境: Maven的環境需要jdk環境的支持,首先要保證本機上已經有jdk環境,並且環境變數配置成功。 下載地址:http://maven.ap ...
  • 通過配置文件的方式實現一個簡單的HelloWorld。 一、新建項目 1、新建動態web項目 2、命名工程springmvc-01 3、勾選"Generate web.xml deployment descriptor" 4、導入jar包 5、新建springmvc配置文件 6、命名配置文件spri ...
  • ...
  • Django 遵從 MVC 模型,並將其特色化為 MTV 模型。模型的核心是通過用戶訪問的 url 來指向處理的函數,而函數處理後返回相應的結果。所以url決定了用戶訪問的入口,另外表單處理的提交地址也需要指定的url。url是所有功能的入口,所以url的編寫就變得非常重要。 Django 的 ur ...
  • <?php //php操作memcache的使用測試總結--學習 //1 Memcache::connect; //$memcache = new Memcache; //$memcache->connect('127.0.0.1',11211) or die("鏈接失敗!"); //2 Memca ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...