zoukankan      html  css  js  c++  java
  • Linux学习篇(十三):Linux 日志信息的查看

    关于内核日志的两个主要文件:

    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命令

    << 转载需注明出处 >>
  • 相关阅读:
    Python的容器类型的遍历汇总
    python学习0313作业
    Python的字符编码
    hadoop-sqoop学习笔记
    eclipse Git & maven 安装
    使用mongoperf评估磁盘随机IO性能
    限制mongodb内存占用过高方法
    rabbitmq集群安装
    Perfmon
    mongodb所在目录空间不足解决方法
  • 原文地址:https://www.cnblogs.com/Huae/p/13776172.html
Copyright © 2011-2022 走看看