2021-05-12 14:32:11
用 coredumpctl 更好地記錄 bug
一個不幸的事實是,所有的軟體都有 bug,一些 bug 會導致系統崩潰。當它出現的時候,它經常會在磁碟上留下一個被稱為“核心轉儲core dump”的資料檔案。該檔案包含有關系統崩潰時的相關資料,可能有助於確定發生崩潰的原因。通常開發者要求提供 “回溯backtrace” 形式的資料,以顯示導致崩潰的指令流。開發人員可以使用它來修復 bug 以改進系統。如果系統發生了崩潰,以下是如何輕鬆生成 回溯backtrace 的方法。
從使用 coredumpctl 開始
大多數 Fedora 系統使用自動錯誤報告工具(ABRT)來自動捕獲崩潰檔案並記錄 bug。但是,如果你禁用了此服務或刪除了該軟體包,則此方法可能會有所幫助。
如果你遇到系統崩潰,請首先確保你執行的是最新的軟體。更新通常包含修復程式,這些更新通常含有已經發現的會導致嚴重錯誤和崩潰的錯誤的修復。當你更新後,請嘗試重現導致錯誤的情況。
如果崩潰仍然發生,或者你已經在執行最新的軟體,那麼可以使用有用的 coredumpctl
工具。此程式可幫助查詢和處理崩潰。要檢視系統上所有核心轉儲列表,請執行以下命令:
coredumpctl list
如果你看到比預期長的列表,請不要感到驚訝。有時系統元件在後台默默地崩潰,並自行恢復。快速查詢今天的轉儲的簡單方法是使用 -since
選項:
coredumpctl list--since=today
“PID” 列包含用於標識轉儲的進程 ID。請注意這個數位,因為你會之後再用到它。或者,如果你不想記住它,使用下面的命令將它賦值給一個變數:
MYPID=<PID>
要檢視關於核心轉儲的資訊,請使用此命令(使用 $MYPID
變數或替換 PID 編號):
coredumpctl info $MYPID
安裝 debuginfo 包
在核心轉儲中的資料以及原始程式碼中的指令之間偵錯符號跳脫。這個符號資料可能相當大。與大多數使用者執行在 Fedora 系統上的軟體包不同,符號以 “debuginfo” 軟體包的形式安裝。要確定你必須安裝哪些 debuginfo 包,請先執行以下命令:
coredumpctl gdb $MYPID
這可能會在螢幕上顯示大量資訊。最後一行可能會告訴你使用 dnf
安裝更多的 debuginfo 軟體包。用 sudo 執行該命令以安裝:
sudo dnf debuginfo-install <packages...>
然後再次嘗試 coredumpctl gdb $MYPID
命令。你可能需要重複執行此操作,因為其他符號會在回溯中展開。
捕獲回溯
在偵錯程式中執行以下命令以記錄資訊:
set logging file mybacktrace.txt
set logging on
你可能會發現關閉分頁有幫助。對於長的回溯,這可以節省時間。
set pagination off
現在執行回溯:
thread apply all bt full
現在你可以輸入 quit
來退出偵錯程式。mybacktrace.txt
包含可附加到 bug 或問題的追蹤資訊。或者,如果你正在與某人實時合作,則可以將文字上傳到 pastebin。無論哪種方式,你現在可以向開發人員提供更多的幫助來解決問題。
作者簡介:
Paul W. Frields
Paul W. Frields 自 1997 年以來一直是 Linux 使用者和愛好者,並於 2003 年在 Fedora 發布不久後加入 Fedora。他是 Fedora 專案委員會的創始成員之一,從事文件、網站發布、宣傳、工具鏈開發和維護軟體。他於 2008 年 2 月至 2010 年 7 月加入 Red Hat,擔任 Fedora 專案負責人,現任紅帽公司工程部經理。他目前和妻子和兩個孩子住在弗吉尼亞州。
via: https://fedoramagazine.org/file-better-bugs-coredumpctl/
作者:Paul W. Frields 譯者:geekpi 校對:wxy
本文永久更新連結地址:http://www.linuxidc.com/Linux/2017-11/148979.htm
相關文章