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

相关文章

nginx启动命令和默认配置文件的使用

《nginx启动命令和默认配置文件的使用》:本文主要介绍nginx启动命令和默认配置文件的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录常见命令nginx.conf配置文件location匹配规则图片服务器总结常见命令# 默认配置文件启动./nginx

SQLite3命令行工具最佳实践指南

《SQLite3命令行工具最佳实践指南》SQLite3是轻量级嵌入式数据库,无需服务器支持,具备ACID事务与跨平台特性,适用于小型项目和学习,sqlite3.exe作为命令行工具,支持SQL执行、数... 目录1. SQLite3简介和特点2. sqlite3.exe使用概述2.1 sqlite3.exe

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

基于Python实现一个Windows Tree命令工具

《基于Python实现一个WindowsTree命令工具》今天想要在Windows平台的CMD命令终端窗口中使用像Linux下的tree命令,打印一下目录结构层级树,然而还真有tree命令,但是发现... 目录引言实现代码使用说明可用选项示例用法功能特点添加到环境变量方法一:创建批处理文件并添加到PATH1

使用jenv工具管理多个JDK版本的方法步骤

《使用jenv工具管理多个JDK版本的方法步骤》jenv是一个开源的Java环境管理工具,旨在帮助开发者在同一台机器上轻松管理和切换多个Java版本,:本文主要介绍使用jenv工具管理多个JD... 目录一、jenv到底是干啥的?二、jenv的核心功能(一)管理多个Java版本(二)支持插件扩展(三)环境隔

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

详解Linux中常见环境变量的特点与设置

《详解Linux中常见环境变量的特点与设置》环境变量是操作系统和用户设置的一些动态键值对,为运行的程序提供配置信息,理解环境变量对于系统管理、软件开发都很重要,下面小编就为大家详细介绍一下吧... 目录前言一、环境变量的概念二、常见的环境变量三、环境变量特点及其相关指令3.1 环境变量的全局性3.2、环境变

Linux系统中的firewall-offline-cmd详解(收藏版)

《Linux系统中的firewall-offline-cmd详解(收藏版)》firewall-offline-cmd是firewalld的一个命令行工具,专门设计用于在没有运行firewalld服务的... 目录主要用途基本语法选项1. 状态管理2. 区域管理3. 服务管理4. 端口管理5. ICMP 阻断

Linux实现线程同步的多种方式汇总

《Linux实现线程同步的多种方式汇总》本文详细介绍了Linux下线程同步的多种方法,包括互斥锁、自旋锁、信号量以及它们的使用示例,通过这些同步机制,可以解决线程安全问题,防止资源竞争导致的错误,示例... 目录什么是线程同步?一、互斥锁(单人洗手间规则)适用场景:特点:二、条件变量(咖啡厅取餐系统)工作流