


Do you really know how to debug Linux kernel failures? You will be enlightened after reading this article!
#The Linux kernel is the core of the operating system, which controls access to system resources (such as CPU, I/O devices, physical memory, and file systems). During the boot process and while the system is running, the kernel writes various messages to the kernel ring buffer. These messages include a variety of information about system operations.
The kernel ring buffer is a part of physical memory used to save the kernel's log messages. It has a fixed size, which means that once the buffer is full, older log records will be overwritten.
The dmesg command line utility is used to print and control the kernel ring buffer in Linux and other Unix-like operating systems. Useful for inspecting kernel boot messages and debugging hardware-related issues.
In this tutorial, we will cover the basics of the dmesg command.
Use the dmesg command
The syntax of the dmesg command is as follows:
dmesg [OPTIONS] 在不带任何选项的情况下调用时,dmesg将所有消息从内核环形缓冲区写入标准输出:
$ dmesg
Default , all users can run the dmesg command. However, on some systems, access to dmesg may be restricted to non-root users. In this case, you will receive the following error message when calling dmesg:
dmesg: readkernel buffer failed: Operation not permitted
Kernel parameterskernel.dmesg_restrictSpecifies whether non-privileged users can use dmesg to view messages from the kernel log buffer information. To remove the restriction, set it to zero:
$ sudo sysctl -w kernel.dmesg_restrict=0
Typically the output contains many lines of information, so only See the last part of the output. To view one page at a time, pipe the output to a paging utility such as less or more:
$ dmesg --color=always | less
where The --color=always parameter is used to preserve colored output.
If you want to filter buffer messages, you may use grep. For example, to view only USB-related messages, type:
$ dmesg | grep -i usb
dmesg 从/proc/kmsg虚拟文件中读取内核生成的消息。该文件提供了到内核环形缓冲区的接口,并且只能由一个进程打开。如果系统上正在运行syslog进程,并且你尝试使用cat或less命令读取文件,则命令将挂起。
syslog守护程序将内核消息转储到/var/log/dmesg,因此你也可以使用该日志文件:
$ cat /var/log/dmesg
格式化 dmesg 输出。
dmesg命令提供了许多选项,可帮助你格式化和过滤输出。
dmesg中最常用的选项之一是-H(--human),它将输出更容易读的结果。
$ dmesg -H
要打印人类可读的时间戳,请使用-T(--ctime选项):
$ dmesg -T [Mon Oct 14 14:38:04 2019] IPv6: ADDRCONF(NETDEV_CHANGE): wlp1s0: link becomes ready
时间戳格式也可以使用--time-format
$ dmesg --time-format=delta
You can also combine two or more options:
$ dmesg -H -T
To watch the output of the dmesg command in real time, use the -w (--follow) option:
$ dmesg --follow
Filter dmesg output.
You can limit dmesg output to a given facility and level. dmesg supports the following types:
kern-kern message user-user-level message mail-mail system daemon - system daemon auth - security/authorization message - ##syslog - internal syslogd message
- lpr-line printer subsystem
- news-network news subsystem
- -f( The --facility
) option allows you to limit the output to a specific device. The option accepts one or more comma-separated capabilities.
$ dmesg -f kern,daemon
emerg-The system is unavailable alert-Action must be taken immediately crit-Emergency err-Error condition warn-Warning condition notice-Normal but important condition info - Informational debug - Debug level message
-l( --level <list>)
option allows you to limit the output to a defined level, this option accepts one or more comma separated levels. The following command displays only error and critical messages:
$ dmesg -l err,crit
clear ring buffer
-C (--clear ) option allows you to clear the ring buffer:
$ sudo dmesg -C
Only root or a user with sudo privileges can clear the buffer.
To print the buffer contents before clearing, use the -c (--read-clear) option:
$ sudo dmesg -c
If you want to Save the current dmesg log to a file before clearing it, you can redirect the output to a file:
$ dmesg > dmesg_messages
Conclusion
The dmesg command allows you to view and control the kernel ring buffer. It is useful when troubleshooting kernel or hardware issues.
Enter man dmesg in the terminal and you can get information about all available dmesg options.
The above is the detailed content of Do you really know how to debug Linux kernel failures? You will be enlightened after reading this article!. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

DeepSeek is a powerful intelligent search and analysis tool that provides two access methods: web version and official website. The web version is convenient and efficient, and can be used without installation; the official website provides comprehensive product information, download resources and support services. Whether individuals or corporate users, they can easily obtain and analyze massive data through DeepSeek to improve work efficiency, assist decision-making and promote innovation.

There are many ways to install DeepSeek, including: compile from source (for experienced developers) using precompiled packages (for Windows users) using Docker containers (for most convenient, no need to worry about compatibility) No matter which method you choose, Please read the official documents carefully and prepare them fully to avoid unnecessary trouble.

Ouyi OKX, the world's leading digital asset exchange, has now launched an official installation package to provide a safe and convenient trading experience. The OKX installation package of Ouyi does not need to be accessed through a browser. It can directly install independent applications on the device, creating a stable and efficient trading platform for users. The installation process is simple and easy to understand. Users only need to download the latest version of the installation package and follow the prompts to complete the installation step by step.

BITGet is a cryptocurrency exchange that provides a variety of trading services including spot trading, contract trading and derivatives. Founded in 2018, the exchange is headquartered in Singapore and is committed to providing users with a safe and reliable trading platform. BITGet offers a variety of trading pairs, including BTC/USDT, ETH/USDT and XRP/USDT. Additionally, the exchange has a reputation for security and liquidity and offers a variety of features such as premium order types, leveraged trading and 24/7 customer support.

Gate.io is a popular cryptocurrency exchange that users can use by downloading its installation package and installing it on their devices. The steps to obtain the installation package are as follows: Visit the official website of Gate.io, click "Download", select the corresponding operating system (Windows, Mac or Linux), and download the installation package to your computer. It is recommended to temporarily disable antivirus software or firewall during installation to ensure smooth installation. After completion, the user needs to create a Gate.io account to start using it.

Ouyi, also known as OKX, is a world-leading cryptocurrency trading platform. The article provides a download portal for Ouyi's official installation package, which facilitates users to install Ouyi client on different devices. This installation package supports Windows, Mac, Android and iOS systems. Users can choose the corresponding version to download according to their device type. After the installation is completed, users can register or log in to the Ouyi account, start trading cryptocurrencies and enjoy other services provided by the platform.

Causes and solutions for errors when using PECL to install extensions in Docker environment When using Docker environment, we often encounter some headaches...

How to automatically set the permissions of unixsocket after the system restarts. Every time the system restarts, we need to execute the following command to modify the permissions of unixsocket: sudo...
