linux命令:调试必备工具dmesg

2024-06-03 05:52

本文主要是介绍linux命令:调试必备工具dmesg,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在服务器上进行芯片调试时,我们会遇到各种各样的问题,很多问题与操作系统相关。此时就需要了解操作系统发生了哪些事件。

dmesg 是linux系统中用来打印或控制内核缓冲区内容的命令。这个环形缓冲区记录了系统启动以来发生的各种事件消息,包括系统日志、驱动程序消息、硬件错误、内核警告等。

例如,在系统reboot后,通过dmesg可以看到PCI设备枚举过程、可以检查是否发生了异常。

1、常用命令

运行 dmesg命令而不带任何参数,将打印出环形缓冲区的所有消息。

dmesg -T 显示事件发生的时间

dmesg -C 清除内核环形缓存消息

dmesg -c 读取并清除内核环形缓存消息

dmesg -H 以容易阅读的形式显示消息

dmesg -L  dmesg 会根据消息的类型(如错误、警告、信息等)给输出的消息加上不同的颜色。这样做可以提高可读性,使得用户能够更快地区分和识别消息的严重性和类型。

具体来说,使用 -L 或 --color 选项可能会对以下方面产生影响:

错误消息:通常会以红色显示,以突出显示错误,便于用户立即注意到。

警告消息:可能会以黄色显示,用于提醒用户存在潜在问题。

信息性消息:可能以默认终端颜色显示,用于普通信息的输出。

调试消息:可能会以特定的颜色显示,以便于在调试过程中区分调试信息。

其他类型的消息:根据系统配置和 dmesg 实现,其他类型的消息也可能有特定的颜色。

dmesg -T | grep PCI   

通过grep命令筛选出想查看的信息,例如grep PCI可以筛选出PCI设备枚举过程信息。

2、命令参考

Usage:

 dmesg [options]

Options:

 -C, --clear                 clear the kernel ring buffer

 -c, --read-clear            read and clear all messages

 -D, --console-off           disable printing messages to console

 -d, --show-delta            show time delta between printed messages

 -e, --reltime               show local time and time delta in readable format

 -E, --console-on            enable printing messages to console

 -F, --file <file>           use the file instead of the kernel log buffer

 -f, --facility <list>       restrict output to defined facilities

 -H, --human                 human readable output

 -k, --kernel                display kernel messages

 -L, --color                 colorize messages

 -l, --level <list>          restrict output to defined levels

 -n, --console-level <level> set level of messages printed to console

 -P, --nopager               do not pipe output into a pager

 -r, --raw                   print the raw message buffer

 -S, --syslog                force to use syslog(2) rather than /dev/kmsg

 -s, --buffer-size <size>    buffer size to query the kernel ring buffer

 -T, --ctime                 show human readable timestamp (could be

                               inaccurate if you have used SUSPEND/RESUME)

 -t, --notime                don't print messages timestamp

 -u, --userspace             display userspace messages

 -w, --follow                wait for new messages

 -x, --decode                decode facility and level to readable string

 -h, --help     display this help and exit

 -V, --version  output version information and exit

Supported log facilities:

    kern - kernel messages

    user - random user-level messages

    mail - mail system

  daemon - system daemons

    auth - security/authorization messages

  syslog - messages generated internally by syslogd

     lpr - line printer subsystem

    news - network news subsystem

Supported log levels (priorities):

   emerg - system is unusable

   alert - action must be taken immediately

    crit - critical conditions

     err - error conditions

    warn - warning conditions

  notice - normal but significant condition

    info - informational

   debug - debug-level messages

这篇关于linux命令:调试必备工具dmesg的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1026162

相关文章

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

Linux命令之firewalld的用法

《Linux命令之firewalld的用法》:本文主要介绍Linux命令之firewalld的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux命令之firewalld1、程序包2、启动firewalld3、配置文件4、firewalld规则定义的九大

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

Linux之计划任务和调度命令at/cron详解

《Linux之计划任务和调度命令at/cron详解》:本文主要介绍Linux之计划任务和调度命令at/cron的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux计划任务和调度命令at/cron一、计划任务二、命令{at}介绍三、命令语法及功能 :at

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

基于Java实现回调监听工具类

《基于Java实现回调监听工具类》这篇文章主要为大家详细介绍了如何基于Java实现一个回调监听工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录监听接口类 Listenable实际用法打印结果首先,会用到 函数式接口 Consumer, 通过这个可以解耦回调方法,下面先写一个

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的