首頁  >  文章  >  運維  >  linux oops是什麼

linux oops是什麼

青灯夜游
青灯夜游原創
2022-02-24 13:34:583635瀏覽

在linux中,oops表示“驚訝”,是一種訊息提示,意味著系統上運行的某些東西違反了核心規定的規則;oops會產生一個崩潰簽名“crash signature”,可以幫助核心開發人員找出錯誤並提高程式碼品質。

linux oops是什麼

本教學操作環境:linux5.9.8系統、Dell G3電腦。

Linux 核心正在盯著你,當它偵測到系統上運行的某些東西違反了正常核心行為時,它會關閉系統並發出一個「oops」!

如果你檢查你的 Linux 系統上運行的進程,你可能會對一個叫做 “kerneloops” 的進程感到好奇。提示一下,它是 “kernel oops”,而不是 “kerne loops”。

坦白說,「oops」 是 Linux 核心的一部分出現了偏差行為。你有做錯了什麼嗎?可能沒有。但有一些不對勁。而那個做了錯事的進程可能已經被 CPU 結束。最糟糕的是,核心可能會報錯並突然關閉系統。

請注意,「oops」 不是首字母縮寫。它不代表像是「物件導向的程式設計和系統object-oriented programming and systems」 或「超出程式規格out of procedural specs」之類的東西。它實際上就是“哎呀” (oops),就像你剛掉下一杯酒或踩在你的貓身上。哎呀! “oops” 的複數是 “oopses”。

oops 意味著系統上運行的某些東西違反了核心有關正確行為的規則。也許程式碼嘗試採取不允許的程式碼路徑或使用無效指標。不管它是什麼,核心—— 總是在監控進程的錯誤行為—— 很可能會阻止特定進程,並將它做了什麼的訊息寫入控制台、 /var/log/dmesg或 /var/log/kern.log 中。

oops 可能是由核心本身引起的,也可能是某些進程試圖讓核心違反在系統上能做的事以及它們被允許做的事。

oops 將產生一個崩潰簽章crash signature,這可以幫助核心開發人員找出錯誤並提高程式碼品質。

系統上執行的kerneloops 進程可能如下所示:

kernoops 881 1 0 Feb11 ? 00:00:01 /usr/sbin/kerneloops

你可能會注意到該進程不是由root 運行的,而是由名為「kernoops」 的用戶運行的,且它的運行時間極少。實際上,分配給這個特定用戶的唯一任務是運行 kerneloops。

$ sudo grep kernoops /etc/passwd
kernoops:x:113:65534:Kernel Oops Tracking Daemon,,,:/:/bin/false

如果你的 Linux 系統沒有 kerneloops(例如 Debian),你可以考慮加入它。查看這個 Debian 頁面以了解更多資訊。

什麼時候該關注 oops?

一般 oops 沒什麼大不了的。它在一定程度上取決於特定進程所扮演的角色。它也取決於 oops 的類別。

有些 oops 很嚴重,會導致系統恐慌system panic。從技術上講,系統恐慌是 oops 的一個子集(即更嚴重的 oops)。當核心偵測到的問題足夠嚴重以至於核心認為它(核心)必須立即停止運作以防止資料遺失或對系統造成其他損害時會出現。因此,系統需要暫停並重新啟動,以防止任何不一致導致不可用或不可靠。所以系統恐慌其實是為了保護自己免受不可挽回的損害。

總之,所有的核心恐慌都是 oops,但並不是所有的 oops 都是核心恐慌。

/var/log/kern.log 和相關的輪轉日誌(/var/log/kern.log.1/var/log /kern.log.2 等)包含由核心產生並由syslog 處理的日誌。

kerneloops 程式收集並預設將錯誤訊息提交到 http://oops.kernel.org/,在那裡它會被分析並呈現給核心開發者。此程序的設定詳細資訊在 /etc/kerneloops.conf 檔案中指定。你可以使用下面的命令輕鬆查看設定:

$ sudo cat /etc/kerneloops.conf | grep -v ^# | grep -v ^$
[sudo] password for shs:allow-submit = ask
allow-pass-on = yes
submit-url = http://oops.kernel.org/submitoops.phplog-file = /var/log/kern.logsubmit-pipe = /usr/share/apport/kernel_oops

在上面的(預設)設定中,內核問題可以被提交,但要求用戶獲得許可。如果設定為 allow-submit = always,則不會詢問使用者。

調試核心問題是使用 Linux 系統的更高級技巧之一。幸運的是,大多數 Linux 用戶很少或從未經歷過 oops 或核心恐慌。不過,知道像 kerneloops 這樣的進程在系統中執行什麼操作,了解可能會報告什麼以及系統何時遇到嚴重的核心衝突也是很好的。

相關推薦:《Linux影片教學

以上是linux oops是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn