linux核心的帶級別控制

2021-05-02 07:12:46 字數 2637 閱讀 3684

要將linux核心的帶級別控制的printk內容列印出來,在命令列 輸入 dmesg -n 8 就將所有級別的資訊都列印出來

linux命令:dmesg  功能說明:顯示開機資訊。

語 法:dmesg [-cn][-s 《緩衝區大小》]

補充說明:kernel會將開機資訊儲存在ring buffer中。您若是開機時來不及檢視資訊,可利用dmesg來檢視。開機資訊亦儲存在/var/log目錄中,名稱為dmesg的檔案裡。

參 數:

-c 顯示資訊後,清除ring buffer中的內容。

-s《緩衝區大小》 預設定為8196,剛好等於ring buffer的大小。

-n 設定記錄資訊的層級。

printk() 使用說明

核心通過 printk() 輸出的資訊具有日誌級別,日誌級別是通過在 printk() 輸出的字串前加乙個帶尖括號的整數來控制的,如 printk("<6>hello, world!/n");。核心中共提供了八種不同的日誌級別,在 linux/kernel.h 中有相應的巨集對應。

#define kern_emerg      "<0>"    /* system is unusable */  

#define kern_alert      "<1>"    /* action must be taken immediately */  

#define kern_crit       "<2>"    /* critical conditions */  

#define kern_err        "<3>"    /* error conditions */  

#define kern_warning    "<4>"    /* warning conditions */  

#define kern_notice     "<5>"    /* normal but significant */  

#define kern_info       "<6>"    /* informational */  

#define kern_debug      "<7>"    /* debug-level messages */ 

#define kern_emerg      "<0>"    /* system is unusable */

#define kern_alert      "<1>"    /* action must be taken immediately */

#define kern_crit       "<2>"    /* critical conditions */

#define kern_err        "<3>"    /* error conditions */

#define kern_warning    "<4>"    /* warning conditions */

#define kern_notice     "<5>"    /* normal but significant */

#define kern_info       "<6>"    /* informational */

#define kern_debug      "<7>"    /* debug-level messages */

所以 printk() 可以這樣用:printk(kern_info "hello, world!/n");。

未指定日誌級別的 printk() 採用的預設級別是 default_message_loglevel,這個巨集在 kernel/printk.c 中被定義為整數 4,即對應kern_warning。

在 /proc/sys/kernel/printk 會顯示4個數值(可由 echo 修改),分別表示當前控制台日誌級別、未明確指定日誌級別的預設訊息日誌級別、最小(最高)允許設定的控制台日誌級別、引導時預設的日誌級別。當 printk() 中的訊息日誌級別小於當前控制台日誌級別時,printk 的資訊(要有/n符)就會在控制台上顯示。但無論當前控制台日誌級別是何值,通過 /proc/kmsg (或使用dmesg)總能檢視。另外如果配置好並執行了 syslogd 或 klogd,沒有在控制台上顯示的 printk 的資訊也會追加到 /var/log/messages.log 中。

通過讀寫/proc/sys/kernel/printk檔案可讀取和修改控制台的日誌級別。檢視這個檔案的方法如下:

#cat /proc/sys/kernel/printk

6 4 1 7

上面顯示的4個資料分別對應控制台日誌級別、預設的訊息日誌級別、最低的控制台日誌級別和預設的控制台日誌級別。

可用下面的命令設定當前日誌級別:

# echo 8 > /proc/sys/kernel/printk

另外為了防止 printk() 瞬時被呼叫次數過多,可以通過 printk_ratelimit() 來控制速度。printk_ratelimit() 通過跟蹤傳送到控制台的訊息數量工作,當輸出速度超過乙個臨界值,就返回零。可通過修改 /proc/sys/kernel/ 來調節 printk_ratelimit() 的計算。

printk_ratelimit() 的典型用法如下:

if (printk_ratelimit())

printk(kern_info "hello, world!/n");

linux核心列印級別

1.printk 是乙個核心的乙個記錄日誌的機制,經常用來記錄資訊或者警告。printk可以指定輸出日誌的優先順序,在include linux kern levels.h中有相應的巨集定義 1 define kern soh 001 ascii start of header 2 define k...

linux核心的列印printk的級別

有時除錯核心模組,列印資訊太多了,可以通過修改 proc sys kernel printk檔案內容來控制。預設設定是6 4 1 7 cat proc sys kernel printk 7 4 1 7 該檔案有四個數字值,它們根據日誌記錄訊息的重要性,定義將其傳送到何處。關於不同日誌級別的更多資訊...

linux列印級別控制原理

在乙個公用的標頭檔案裡面放入 define rt debug error 1 define rt debug warn 2 define rt debug trace 3 define rt debug info 4 unsigned long rtdebuglevel rt debug error...