关于内核日志的两个主要文件:
1. /var/log/dmesg
2. /var/log/messages
dmesg 记录着开机时的内核日志,终端输入 dmesg 就可以查看文件dmesg 文件的内容 。printk ( ) 函数打印的日志可写到dmesg 或 messages 文件中。咦~ 这个树莓派的系统/var/log/下竟然没有 messages 文件。
关于printk( ):
内核中不能直接调用C标准库的函数比如printf ( ),但他有内核函数 比如 printk。题外话:Linux内核 内核可以通过user_modehelper( ) 来调用用户空间的可执行文件(如shell 脚本)。通过 printk() 输出的日志信息具有不同级别,日志级别是通过在 printk() 输出的字符串前加一个带尖括号的整数来控制的,如 printk("<4>Hello, world!/n"); ,尖括号数字组合 也可用 与之对应的宏定义字符串来代替。 如 <0> 可替换为 KERN_EMERG,所以 printk() 可以这样用: printk(KERN_WARNING "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() 采用的默认级别是 DEFAULT_MESSAGE_LOGLEVEL,这个宏在 kernel/printk.c 中被定义为整数 4,即对应KERN_WARNING。
参考文章: 1. dmesg 总结 2. dmesg与printk命令