zoukankan      html  css  js  c++  java
  • 内核打印等级

    内核打印日志等级配置存放在/proc/sys/kernel/printk,默认6   4   1   7

    上面显示的4个数据分别对应:

    控制台日志级别:优先级高于该值的消息将被打印至控制台

    默认的消息日志级别:将用该优先级来打印没有优先级的消息

    最低的控制台日志级别:控制台日志级别可被设置的最小值(最高优先级)

    默认的控制台日志级别:控制台日志级别的缺省值

    数值越小,优先级越高

                    其实这四个值是在kernel/printk.c 中被定义的,如下:

    int console_printk[4] = {

                    DEFAULT_CONSOLE_LOGLEVEL,       /* console_loglevel */

                    DEFAULT_MESSAGE_LOGLEVEL,       /* default_message_loglevel */

                    MINIMUM_CONSOLE_LOGLEVEL,     /* minimum_console_loglevel */

                    DEFAULT_CONSOLE_LOGLEVEL,       /* default_console_loglevel */

    };

    内核通过printk() 输出的信息具有日志级别,日志级别是通过在printk() 输出的字符串前加一个带尖括号的整数来控制的,如printk("<6>Hello, world! ");。内核中共提供了八种不同的日志级别,在 linux/kernel.h 中有相应的宏对应。

    #define KERN_EMERG  "<0>"   /* systemis unusable */

    #define KERN_ALERT  "<1>"   /* actionmust be taken immediately */

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

    #define KERN_ERR     "<3>"   /* errorconditions */

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

    #define KERN_NOTICE  "<5>"   /* normalbut significant */

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

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

    所以printk() 可以这样用:printk(KERN_INFO"Hello, world! ");。

    未指定日志级别的printk() 采用的默认级别是DEFAULT_MESSAGE_LOGLEVEL,这个宏在kernel/printk.c 中被定义为整数4,即对应KERN_WARNING。

    如果要想在内核启动过程中打印少的信息,就可以根据自己的需要在kernel/printk.c中修改以上数值,重新编译即可!

    /* printk's without a loglevel use this.. */

    #define DEFAULT_MESSAGE_LOGLEVEL 4 /* KERN_WARNING */


  • 相关阅读:
    Django学习(二) Django框架简单搭建
    Django学习(一) Django安装配置
    Python学习(一) Python安装配置
    注册第一天,纪念一下
    小程序笔记
    详解HTML5中的进度条progress元素简介及兼容性处理
    服务管理
    yum
    管道,输出,管道,重定向,grep
    VIM
  • 原文地址:https://www.cnblogs.com/enki-fang/p/8672204.html
Copyright © 2011-2022 走看看