printk的日志级别和控制台级别
来源:互联网 发布:apache 不能解析php 编辑:程序博客网 时间:2024/05/09 01:50
printk根据日志级别(loglevel)对消息进行分类。日志级别用宏定义,日志级别宏展开为一个字符串,在编译时由预处理器将它和消息文本拼接成一个字符串,因此printk 函数中日志级别宏和格式字符串间不能有逗号。
下面是两个printk的例子,一个用于打印调试信息,另一个用于打印临界条件信息。
printk(KERN_DEBUG "Here I am: %s:%i/n", _ _FILE_ _, _ _LINE_ _); printk(KERN_CRIT "I'm trashed; giving up on %p/n", ptr);
printk的日志级别定义如下(在linux26/includelinux/kernel.h中):
#defineKERN_EMERG"<0>"#defineKERN_ALERT"<1>"#defineKERN_CRIT"<2>"#defineKERN_ERR"<3>"#defineKERN_WARNING"<4>"#defineKERN_NOTICE"<5>"#defineKERN_INFO"<6>"#defineKERN_DEBUG"<7>" extern int console_printk[]; #define console_loglevel (console_printk[0])#define default_message_loglevel (console_printk[1])#define minimum_console_loglevel (console_printk[2])#define default_console_loglevel (console_printk[3])
日志级别的范围是0~7,没有指定日志级别的printk语句默认采用的级别是 DEFAULT_ MESSAGE_LOGLEVEL,其定义列出如下(在linux26/kernel/printk.c中):
#define DEFAULT_MESSAGE_LOGLEVEL 4
内核可把消息打印到当前控制台上,可以指定控制台为字符模式的终端或打印机等。默认情况下,“控制台”就是当前的虚拟终端。
为了更好地控制不同级别的信息显示在控制台上,内核设置了控制台的日志级别console_loglevel。printk日志级别的作用是打印一定级别的消息,与之类似,控制台只显示一定级别的消息。
当printk的日志级别小于console_loglevel时,消息才能显示出来。控制台相应的日志级别定义如下:
#define MINIMUM_CONSOLE_LOGLEVEL 1 #define DEFAULT_CONSOLE_LOGLEVEL 7 int console_printk[4] = {DEFAULT_CONSOLE_LOGLEVEL, DEFAULT_MESSAGE_LOGLEVEL, MINIMUM_CONSOLE_LOGLEVEL,DEFAULT_CONSOLE_LOGLEVEL,};
如果系统运行了klogd和syslogd,则无论console_loglevel为何值,内核消息都将追加到/var/log/messages中。如果klogd没有运行,消息不会传递到用户空间,只能查看/proc/kmsg。
变量console_loglevel的初始值是DEFAULT_CONSOLE_LOGLEVEL,可以通过sys_syslog系统调用进行修改。调用klogd时可以指定-c开关选项来修改这个变量。如果要修改它的当前值,必须先杀掉klogd,再加-c选项重新启动它。
注:#ps -e 查看所有进程PID,然后KILL。
通过读写/proc/sys/kernel/printk文件可读取和修改控制台的日志级别。查看这个文件的方法如下:
#cat /proc/sys/kernel/printk6 4 1 7
上面显示的4个数据分别对应控制台日志级别、默认的消息日志级别、最低的控制台日志级别和默认的控制台日志级别。
可用下面的命令设置当前日志级别:
# echo 8 > /proc/sys/kernel/printk
- printk的日志级别和控制台级别
- printk及控制台的日志级别
- printk及控制台的日志级别
- printk及控制台的日志级别
- printk及控制台的日志级别
- 2.1.3 printk及控制台的日志级别
- 内核printk的日志级别
- printk日志级别
- 修改printk日志级别
- 驱动程序 没在控制台输出原因 printk及控制台的日志级别
- 驱动程序 没在控制台输出原因 printk及控制台的日志级别
- 驱动程序 没在控制台输出原因 printk及控制台的日志级别
- 内核printk日志信息的级别
- 内核printk日志信息的级别
- 内核printk日志信息的级别
- 内核printk日志信息的级别
- printk函数日志级别的设置
- printk的打印级别
- 原型模式
- Erlang将在并发领域取代java
- TextView闪烁的问题
- Windows 下Memcache安装配置
- Oracle Exception Handling Version 11.1
- printk的日志级别和控制台级别
- 你是个好人
- FFMpeg编译之路(转)
- 实验一 中文数据库检索
- Eclipse快捷键大全
- api函数大全
- blackfin bf5x 学习 1 L1 设置成 sram和 cache区别 和作用不同。
- C 语言资料大全
- Python - optparse 之 OptionParser