【国产化】Linux命令速学之 dmesg 命令
nanshan 2024-10-22 13:04 22 浏览 0 评论
1. dmesg 命令简介
dmesg 命令用于查看和控制 Linux 内核环形缓冲区(the kernel ring buffer),从而深入了解硬件错误和启动问题。kylin / UOS / CentOS 等 Linux 各版本通用,需要 root 权限。
1.1. Linux 的启动过程
在 Linux 中,引导 boot 和启动 startup 是计算机通电时发生的两个不同阶段。
引导进程(BIOS 或 UEFI、MBR 和 GRUB)将系统初始化到把内核加载到内存并连接到初始 ramdisk 的点,然后启动 systemd。
然后启动过程继续完成操作系统的初始化。在初始化的早期阶段,日志守护程序(如 syslogd 或 rsyslogd)尚未启动和运行。为了避免丢失此初始化阶段的显著错误和警告消息,内核包含一个用作消息存储的环形缓冲区,它就是 kernel ring buffer。
1.2. 内核环形缓冲区
内核环形缓冲区是为消息保留的内存空间。它设计简单,大小固定。当消息满时,较新的消息会覆盖最旧的消息。从概念上讲,它可以被认为是一个“循环缓冲区”。
内核环形缓冲区存储:
- 设备驱动程序的初始化消息,
- 来自硬件的消息,
- 来自内核模块的消息之类的信息。
因为它包含这些底层启动消息,所以环形缓冲区是调查硬件错误或其他启动问题的好地方。
2. 语法
dmesg [options]
# 举例,输出彩色文本
dmesg -L
# 查看错误信息
dmesg -l err
详细的参数,见第4节。
3. 常用命令
3.1. dmesg | less
查看内核环形缓冲区中的消息。
[root@centos ~]# dmesg
- CentOS 7 的效果,没有彩色输出
- Kylin 的效果,彩色输出
- UOS D 版效果,彩色输出
- CentOS 7 带上参数 -L 彩色输出
# 单次彩色输出
dmesg -L
# 设置始终彩色输出
dmesg --color=always
3.2. dmesg --follow
实时跟随查看最新的消息,与 tail 一样使用 follow 参数。
[root@kylin ~]# dmesg --follow
3.3. dmesg | tail -10
查看最后 n 条消息。
# 麒麟
[root@kylin ~]# dmesg | tail -3
[ 16.193827] aufs 4.19-20200518
[ 16.674474] bridge: filtering via arp/ip/ip6tables is no longer available by default. Update your scripts to load br_netfilter if you need this.
[ 16.682935] Bridge firewalling registered
# CentOS
[root@centos ~]# dmesg | tail -3
[ 15.746026] work still pending
[ 15.832549] nf_conntrack version 0.5.0 (16384 buckets, 65536 max)
[ 15.978076] bridge: filtering via arp/ip/ip6tables is no longer available by default. Update your scripts to load br_netfilter if you need this.
# 统信
root@uos:~# dmesg | tail -3
[ 9.769158] IPv6: ADDRCONF(NETDEV_UP): ens32: link is not ready
[ 9.776385] e1000: ens32 NIC Link is Up 1000 Mbps Full Duplex, Flow Control: None
[ 9.779098] IPv6: ADDRCONF(NETDEV_CHANGE): ens32: link becomes ready
3.4. dmesg | grep -i usb
查看含指定内容的消息。
root@uos:/home/uroot# dmesg | grep -i usb
[ 1.100098] ACPI: bus type USB registered
[ 1.100182] usbcore: registered new interface driver usbfs
[ 1.100191] usbcore: registered new interface driver hub
[ 1.100269] usbcore: registered new device driver usb
[ 3.495188] ehci_hcd: USB 2.0 'Enhanced' Host Controller (EHCI) Driver
[ 3.495197] ohci_hcd: USB 1.1 'Open' Host Controller (OHCI) Driver
[ 3.495350] usbcore: registered new interface driver usbserial_generic
[ 3.495352] usbserial: USB Serial support registered for generic
# extend regular expression
root@uos:/home/uroot# dmesg | grep -E "memory|tty|dma"
[ 0.054314] Early memory node ranges
[ 0.081626] PM: Registered nosave memory: [mem 0x00000000-0x00000fff]
[ 0.081627] PM: Registered nosave memory: [mem 0x0009e000-0x0009efff]
[ 0.081627] PM: Registered nosave memory: [mem 0x0009f000-0x0009ffff]
[ 0.081628] PM: Registered nosave memory: [mem 0x000a0000-0x000dbfff]
[ 0.081628] PM: Registered nosave memory: [mem 0x000dc000-0x000fffff]
[ 0.081629] PM: Registered nosave memory: [mem 0x7fee0000-0x7fefefff]
[ 0.081629] PM: Registered nosave memory: [mem 0x7feff000-0x7fefffff]
[ 0.393660] console [tty0] enabled
3.5. dmesg -l err
按 log 等级查看消息。
[root@centos ~]# dmesg -l err
[ 8.341761] sd 0:0:0:0: [sda] Assuming drive cache: write through
[ 12.825902] piix4_smbus 0000:00:07.3: SMBus Host Controller not enabled!
日志等级见第 4 节。
3.6. dmesg -f daemon
按设施类型查看消息。
[root@kylin ~]# dmesg -f daemon
[ 1.708627] systemd[1]: systemd v243-55.p06.se.01.ky10 running in system mode. (+PAM +AUDIT +SELINUX +IMA -APPARMOR +SMACK +SYSVINIT +UTMP +LIBCRYPTSETUP +GCRYPT +GNUTLS +ACL +XZ +LZ4 +SECCOMP +BLKID +ELFUTILS +KMOD +IDN2 -IDN +PCRE2 default-hierarchy=legacy)
[ 1.708700] systemd[1]: Detected virtualization vmware.
[ 1.708707] systemd[1]: Detected architecture x86-64.
[ 1.708708] systemd[1]: Running in initial RAM disk.
[ 1.710818] systemd[1]: Set hostname to <kylin>.
[ 1.791011] systemd[1]: Reached target Local File Systems.
设施类型见第 4 节。
4. dmesg 命令详解
dmesg 命令的详细参数说明如下:
支持的设施类别:
kern - 内核消息
user - 随机的用户级消息
mail - 邮件系统
daemon - 系统守护进程
auth - 安全/认证消息
syslog - syslogd 内部生成的消息
lpr - 行打印机子系统
news - 网络新闻子系统
支持的日志级别(优先级):
emerg - 系统无法使用
alert - 操作必须立即执行
crit - 紧急条件
err - 错误条件
warn - 警告条件
notice - 正常但重要的条件
info - 信息
debug - 调试级别的消息
Enjoy[啤酒][啤酒][啤酒]
相关推荐
- HTTP 和 HTTPS 有何不同?一文带你全面了解
-
随着互联网时代的高速发展,Web服务器和客户端之间的安全通信需求也越来越高。HTTP和HTTPS是两种广泛使用的Web通信协议。本文将介绍HTTP和HTTPS的区别,并探讨为什么HTTPS已成为We...
- HTTP和HTTPS的区别?
-
本文主要讲解http和https的关系与区别,分辨不清区别的同学要注意朝下看完,Web面试中最常问的已到面试题~~一.HTTP和HTTPS的相同点:大多数情况下,HTTP和HTTPS是相同的,...
- 详解HTTP协议与RESTFUL
-
1.HTTP简介http协议是一种超文本传输协议,主要应用在浏览器与服务器之间的通信,可以传输文本,图片,视频等。它是一种应用层协议,也是基于TCP协议,当然现在流行的Https协议是在TLS或SSL...
- http与https的区别,读完之后,大部分程序员收藏了...
-
在URL前加https://前缀表明是用SSL加密的。你的电脑与服务器之间收发的信息传输将更加安全。Web服务器启用SSL需要获得一个服务器证书并将该证书与要使用SSL的服务器绑定。http和ht...
- JMeter测试HTTP GET请求(附实例)
-
一、HTTPRequest配置项解析●WebServer:1.Protocol[http]:○若为HTTP协议可以不填写(默认为HTTP);○若为HTTPS协议可以填写“https”;还可...
- 2019山东高考分数线公布:本科文503 理443
-
刚刚,2019年山东高考各批次录取最低分数线公布了!6月24日下午,山东省教育厅举行2019年山东高考第二场新闻发布会。山东省教育招生考试院在发布会上公布了山东今年高招各批次录取控制分数线。其中,本科...
- Linux系统网站出现503错误提示怎么解决?
-
当Linux系统上的网站出现503ServiceUnavailable错误时,通常表示服务器暂时无法处理请求,可能由后端服务崩溃、资源耗尽或配置错误导致。以下是系统化的排查和解决方案:一、...
- 三石说:一文带你了解Https
-
今天我们继续深入http,本篇将介绍Https的内容,相信你看过之后对https有一定的了解。HTTPSHTTPS(全称:HyperTextTransferProtocoloverSecu...
- HTTP与HTTPS的区别
-
首先,需要知道HTTP和HTTPS是什么。HTTP是超文本传输协议,是一个基于请求与响应,无状态的,应用层的协议,常基于TCP/IP协议传输数据,是互联网上应用最为广泛的一种网络协议。也...
- Caddy服务器开启HTTP/3:如何让你的网站快如闪电?
-
Caddy服务器开启HTTP/3:如何让你的网站快如闪电?在互联网技术飞速迭代的今天,HTTP/3正以革命性的姿态颠覆传统网络传输模式。作为首个基于QUIC协议的HTTP标准,它不仅能大幅提升网站加载...
- HTTP/1.1、HTTP/2、HTTP/3 演变
-
HTTP基本概念HTTP是超文本传输协议,也就是HyperTextTransferProtocol。HTTP常见的状态码有哪些?1xx类状态码属于提示信息,是协议处理中的一种中间状态,实际...
- HTTP/3 黑科技:三次握手如何进阶 QUIC?30 年通信细节揭秘
-
大家好,我是“极客运维社”的飞哥,点击右上方“关注”,每天和大家分享关于网络设备及系统和企业组网方面干货。码字不易,如果您觉得文章还可以,就点赞+关注+收藏吧,也许在以后某个时间能够用得到。H...
- 总结HTTP/HTTPS协议基础的有那些漏洞,怎么检查,怎么防范
-
以下是基于黑盒测试、白盒测试和灰盒测试视角对HTTP/HTTPS协议漏洞检查与防范的分类整理:一、黑盒测试(外部视角,无内部权限)定义:模拟攻击者视角,仅通过外部网络接口进行测试,不依赖系...
- 什么是HTTP? HTTP 和 HTTPS 的区别?
-
HTTP(HyperTextTransferProtocol),即超文本运输协议,是实现网络通信的一种规范。HTTP是一个传输协议,即将数据由A传到B或将B传输到A,并且A与B之间能够存...
- 一篇文章搞懂HTTP和HTTPS的的本质区别
-
http协议是基于tcp协议,默认是80端口。它的特点是什么?它是基于请求和响应的,大家抓个包能看到http协议有一个请求报文有一个响应报文,还有它是一个无状态的协议,还有一个无连接的协议。无连接是指...
你 发表评论:
欢迎- 一周热门
-
-
爱折腾的特斯拉车主必看!手把手教你TESLAMATE的备份和恢复
-
如何在安装前及安装后修改黑群晖的Mac地址和Sn系列号
-
[常用工具] OpenCV_contrib库在windows下编译使用指南
-
WindowsServer2022|配置NTP服务器的命令
-
Ubuntu系统Daphne + Nginx + supervisor部署Django项目
-
WIN11 安装配置 linux 子系统 Ubuntu 图形界面 桌面系统
-
解决Linux终端中“-bash: nano: command not found”问题
-
NBA 2K25虚拟内存不足/爆内存/内存占用100% 一文速解
-
Linux 中的文件描述符是什么?(linux 打开文件表 文件描述符)
-
K3s禁用Service Load Balancer,解决获取浏览器IP不正确问题
-
- 最近发表
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)