dmesg命令用于打印Linux系统开机启动信息,kernel会将开机信息存储在ring buffer中。您若是开机时来不及查看信息,可利用dmesg来查看(print or control the kernel ring buffer)。开机信息亦保存在/var/log/dmesg的文件里。某些硬件设备(比如七号信令卡、语音卡之类)在安装的时候,通常会安装驱动程序(内核模块),会打印一些信息,就可以通过dmesg命令来查看。

格式:dmesg

查看开机信息。

格式:dmesg -c

清除开机信息,但/var/log/dmesg文件中仍然有这些信息。

dmesg 命令的使用范例

‘dmesg’命令设备故障的诊断是非常重要的。在‘dmesg’命令的帮助下进行硬件的连接或断开连接操作时,我们可以看到硬件的检测或者断开连接的信息。‘dmesg’命令在多数基于LinuxUnix的操作系统中都可以使用。

下面我们展示一些最负盛名的‘dmesg’命令工具以及其实际使用举例。‘dmesg’命令的使用语法如下。

# dmesg [options...]

1. 列出加载到内核中的所有驱动

我们可以使用如‘more’。 ‘tail’, ‘less ’或者‘grep’文字处理工具来处理‘dmesg’命令的输出。由于dmesg日志的输出不适合在一页中完全显示,因此我们使用管道(pipe)将其输出送到more或者less命令单页显示。

[root@tecmint.com ~]# dmesg | more

[root@tecmint.com ~]# dmesg | less

输出

[    0.000000] Initializing cgroup subsys cpuset

[    0.000000] Initializing cgroup subsys cpu

[    0.000000] Initializing cgroup subsys cpuacct

[    0.000000] Linux version 3.11.0-13-generic (buildd@aatxe) (gcc version 4.8.1 (Ubuntu/Linaro 4.8.1-10ubuntu8) ) #20-Ubuntu SMP Wed Oct 23 17:26:33 UTC 2013

(Ubuntu 3.11.0-13.20-generic 3.11.6)

[    0.000000] KERNEL supported cpus:

[    0.000000]   Intel GenuineIntel

[    0.000000]   AMD AuthenticAMD

[    0.000000]   NSC Geode by NSC

[    0.000000]   Cyrix CyrixInstead

[    0.000000]   Centaur CentaurHauls

[    0.000000]   Transmeta GenuineTMx86

[    0.000000]   Transmeta TransmetaCPU

[    0.000000]   UMC UMC UMC UMC

[    0.000000] e820: BIOS-provided physical RAM map:

[    0.000000] BIOS-e820: [mem 0x0000000000000000-0x000000000009fbff] usable

[    0.000000] BIOS-e820: [mem 0x00000000000f0000-0x00000000000fffff] reserved

[    0.000000] BIOS-e820: [mem 0x0000000000100000-0x000000007dc08bff] usable

[    0.000000] BIOS-e820: [mem 0x000000007dc08c00-0x000000007dc5cbff] ACPI NVS

[    0.000000] BIOS-e820: [mem 0x000000007dc5cc00-0x000000007dc5ebff] ACPI data

[    0.000000] BIOS-e820: [mem 0x000000007dc5ec00-0x000000007fffffff] reserved

[    0.000000] BIOS-e820: [mem 0x00000000e0000000-0x00000000efffffff] reserved

[    0.000000] BIOS-e820: [mem 0x00000000fec00000-0x00000000fed003ff] reserved

[    0.000000] BIOS-e820: [mem 0x00000000fed20000-0x00000000fed9ffff] reserved

[    0.000000] BIOS-e820: [mem 0x00000000fee00000-0x00000000feefffff] reserved

[    0.000000] BIOS-e820: [mem 0x00000000ffb00000-0x00000000ffffffff] reserved

[    0.000000] NX (Execute Disable) protection: active

.....

2. 列出所有被检测到的硬件

要显示所有被内核检测到的硬盘设备,你可以使用‘grep’命令搜索‘sda’关键词,如下:

[root@tecmint.com ~]# dmesg | grep sda

[    1.280971] sd 2:0:0:0: [sda] 488281250 512-byte logical blocks: (250 GB/232 GiB)

[    1.281014] sd 2:0:0:0: [sda] Write Protect is off

[    1.281016] sd 2:0:0:0: [sda] Mode Sense: 00 3a 00 00

[    1.281039] sd 2:0:0:0: [sda] Write cache: enabled, read cache: enabled, doesn't support DPO or FUA

[    1.359585]  sda: sda1 sda2 < sda5 sda6 sda7 sda8 >

[    1.360052] sd 2:0:0:0: [sda] Attached SCSI disk

[    2.347887] EXT4-fs (sda1): mounted filesystem with ordered data mode. Opts: (null)

[   22.928440] Adding 3905532k swap on /dev/sda6.  Priority:-1 extents:1 across:3905532k FS

[   23.950543] EXT4-fs (sda1): re-mounted. Opts: errors=remount-ro

[   24.134016] EXT4-fs (sda5): mounted filesystem with ordered data mode. Opts: (null)

[   24.330762] EXT4-fs (sda7): mounted filesystem with ordered data mode. Opts: (null)

[   24.561015] EXT4-fs (sda8): mounted filesystem with ordered data mode. Opts: (null)

注解 ‘sda’表示第一块 SATA硬盘,‘sdb’表示第二块SATA硬盘。若想查看IDE硬盘搜索‘hda’或‘hdb’关键词。

3. 只输出dmesg命令的前20行日志

在‘dmesg’命令后跟随‘head’命令来显示开始几行,‘dmesg | head -20′命令将显示开始的前20行。

[root@tecmint.com ~]# dmesg | head  -20

[    0.000000] Initializing cgroup subsys cpuset

[    0.000000] Initializing cgroup subsys cpu

[    0.000000] Initializing cgroup subsys cpuacct

[    0.000000] Linux version 3.11.0-13-generic (buildd@aatxe) (gcc version 4.8.1 (Ubuntu/Linaro 4.8.1-10ubuntu8) ) #20-Ubuntu SMP Wed Oct 23 17:26:33 UTC 2013 (Ubuntu 3.11.0-13.20-generic 3.11.6)

[    0.000000] KERNEL supported cpus:

[    0.000000]   Intel GenuineIntel

[    0.000000]   AMD AuthenticAMD

[    0.000000]   NSC Geode by NSC

[    0.000000]   Cyrix CyrixInstead

[    0.000000]   Centaur CentaurHauls

[    0.000000]   Transmeta GenuineTMx86

[    0.000000]   Transmeta TransmetaCPU

[    0.000000]   UMC UMC UMC UMC

[    0.000000] e820: BIOS-provided physical RAM map:

[    0.000000] BIOS-e820: [mem 0x0000000000000000-0x000000000009fbff] usable

[    0.000000] BIOS-e820: [mem 0x00000000000f0000-0x00000000000fffff] reserved

[    0.000000] BIOS-e820: [mem 0x0000000000100000-0x000000007dc08bff] usable

[    0.000000] BIOS-e820: [mem 0x000000007dc08c00-0x000000007dc5cbff] ACPI NVS

[    0.000000] BIOS-e820: [mem 0x000000007dc5cc00-0x000000007dc5ebff] ACPI data

[    0.000000] BIOS-e820: [mem 0x000000007dc5ec00-0x000000007fffffff] reserved

4. 只输出dmesg命令最后20行日志

在‘dmesg’命令后跟随‘tail’命令(‘ dmesg | tail -20’)来输出‘dmesg’命令的最后20行日志,当你插入可移动设备时它是非常有用的。

[root@tecmint.com ~]# dmesg | tail -20

parport0: PC-style at 0x378, irq 7 [PCSPP,TRISTATE]

ppdev: user-space parallel port driver

EXT4-fs (sda1): mounted filesystem with ordered data mode

Adding 2097144k swap on /dev/sda2.  Priority:-1 extents:1 across:2097144k

readahead-disable-service: delaying service auditd

ip_tables: (C) 2000-2006 Netfilter Core Team

nf_conntrack version 0.5.0 (16384 buckets, 65536 max)

NET: Registered protocol family 10

lo: Disabled Privacy Extensions

e1000: eth0 NIC Link is Up 1000 Mbps Full Duplex, Flow Control: None

Slow work thread pool: Starting up

Slow work thread pool: Ready

FS-Cache: Loaded

CacheFiles: Loaded

CacheFiles: Security denies permission to nominate security context: error -95

eth0: no IPv6 routers present

type=1305 audit(1398268784.593:18630): audit_enabled=0 old=1 auid=4294967295 ses=4294967295 res=1

readahead-collector: starting delayed service auditd

readahead-collector: sorting

readahead-collector: finished

5. 搜索包含特定字符串的被检测到的硬件

由于‘dmesg’命令的输出实在太长了,在其中搜索某个特定的字符串是非常困难的。因此,有必要过滤出一些包含‘usb’ ‘dma’ ‘tty’ ‘memory’等字符串的日志行。grep 命令 的‘-i’选项表示忽略大小写。

[root@tecmint.com log]# dmesg | grep -i usb

[root@tecmint.com log]# dmesg | grep -i dma

[root@tecmint.com log]# dmesg | grep -i tty

[root@tecmint.com log]# dmesg | grep -i memory

输出

[    0.000000] Scanning 1 areas for low memory corruption

[    0.000000] initial memory mapped: [mem 0x00000000-0x01ffffff]

[    0.000000] Base memory trampoline at [c009b000] 9b000 size 16384

[    0.000000] init_memory_mapping: [mem 0x00000000-0x000fffff]

[    0.000000] init_memory_mapping: [mem 0x37800000-0x379fffff]

[    0.000000] init_memory_mapping: [mem 0x34000000-0x377fffff]

[    0.000000] init_memory_mapping: [mem 0x00100000-0x33ffffff]

[    0.000000] init_memory_mapping: [mem 0x37a00000-0x37bfdfff]

[    0.000000] Early memory node ranges

[    0.000000] PM: Registered nosave memory: [mem 0x0009f000-0x000effff]

[    0.000000] PM: Registered nosave memory: [mem 0x000f0000-0x000fffff]

[    0.000000] please try 'cgroup_disable=memory' option if you don't want memory cgroups

[    0.000000] Memory: 2003288K/2059928K available (6352K kernel code, 607K rwdata, 2640K rodata, 880K init, 908K bss, 56640K reserved, 1146920K highmem)

[    0.000000] virtual kernel memory layout:

[    0.004291] Initializing cgroup subsys memory

[    0.004609] Freeing SMP alternatives memory: 28K (c1a3e000 - c1a45000)

[    0.899622] Freeing initrd memory: 23616K (f51d0000 - f68e0000)

[    0.899813] Scanning for low memory corruption every 60 seconds

[    0.946323] agpgart-intel 0000:00:00.0: detected 32768K stolen memory

[    1.360318] Freeing unused kernel memory: 880K (c1962000 - c1a3e000)

[    1.429066] [drm] Memory usable by graphics device = 2048M

6. 清空dmesg缓冲区日志

我们可以使用如下命令来清空dmesg的日志。该命令会清空dmesg环形缓冲区中的日志。但是你依然可以查看存储在‘/var/log/dmesg’文件中的日志。你连接任何的设备都会产生dmesg日志输出。

[root@tecmint.com log]# dmesg -c

7. 实时监控dmesg日志输出

在某些发行版中可以使用命令‘tail -f /var/log/dmesg’来实时监控dmesg的日志输出。

[root@tecmint.com log]# watch "dmesg | tail -20"

结论:dmesg命令在系统dmesg记录实时更改或产生的情况下是非常有用的。你可以使用man dmesg来获取更多关于dmesg的信息

转载http://blog.csdn.net/rwdxll/article/details/38560137

dmesg的详细用法相关推荐

  1. Android命令行工具logcat详细用法!

    logcat是Android中一个命令行工具,可以用于得到程序的log信息. 见板凳详细说明!      本贴内容来自网络,引用网址为:http://hi.baidu.com/%C9%C1%D2%AB ...

  2. __declspec关键字详细用法

    __declspec关键字详细用法 2009-01-21 16:23 __declspec用于指定所给定类型的实例的与Microsoft相关的存储方式.其它的有关存储方式的修饰符如static与ext ...

  3. mysql left/right join算法效率分析_mysql left join,right join,inner join超详细用法分析

    MySQL left join,right join,inner join超详细用法分析 下面是例子分析 表A记录如下: aID        aNum 1           a20050111 2 ...

  4. python sort怎么用,Linux Sort命令详细用法(有实例)

    Linux Sort命令详细用法(有实例) sort是在Linux里非常常用的一个命令,管排序的,集中精力,五分钟搞定sort,现在开始! Linux sort命令进阶: 1 sort的工作原理 so ...

  5. vue性能优化-------vendor优化详细用法(瘦身),减小体积,引入cdn

    vue性能优化-------vendor优化详细用法(瘦身),减小体积,引入cdn 原创ChrisWang_ 最后发布于2019-05-24 10:25:58 阅读数 1332  收藏 展开 vue性 ...

  6. oracle rtrim(),Oracle ltrim() rtrim() 函数详细用法

    嘿嘿,今天在论坛里看了一篇帖子,讨论ltrim() 函数的详细用法,下面我借几个高手的回答总结一下: 先看几个实例: SQL> select ltrim('109224323','109') f ...

  7. pythonrange函数用法_python range()函数详细用法

    python range()函数详细用法 函数原型:range(start, end, scan): 参数含义:start:计数从start开始.默认是从0开始.例如range(5)等价于range( ...

  8. python中3 and not 5_python中not、and和or的优先级与详细用法介绍

    前言 (小白专用)本次所分享的是Python中的not.and.or的执行时的优先级,以及他们的具体用法.本文比较详细,不喜勿喷. 一.not.and.or的含义以及优先级 对象 返回结果 优先顺序 ...

  9. Word查找替换详细用法及通配符一览表

    转载自:https://www.cnblogs.com/whchensir/p/5768030.html Word查找替换详细用法及通配符一览表 使用通配符 要查找"?"或者&qu ...

最新文章

  1. Python 爬虫利器 Selenium 从入门到进阶
  2. Vue后台管理系统实现登录功能
  3. 学习Java编程到底是为了什么,该具备什么样的能力
  4. 在JDT中使用Java 8 Lambda
  5. Java-标识符和关键字
  6. python装饰器记录每一个函数的执行时间
  7. (46)FPGA同步复位与异步复位(异步复位)
  8. 一个项目有两个pom_Python Selenium设计模式之POM设计模式
  9. winform基础 C#编程
  10. Mybatis-代码走查问题整理
  11. PyQt5报错Process finished with exit code -1073740791 (0xC0000409)
  12. 【贪心算法】-背包问题
  13. 电脑重装系统后台式电脑网卡坏了怎么修复
  14. 超星计算机技术基础 vb,程序设计技术(VB)-中国大学mooc-题库零氪
  15. 欲报从速,已有56所高校选择云创大学高质量免费直播授课!
  16. SpringBoot+SpringSecurity+JWT整合实现单点登录SSO史上最全详解
  17. oracle语句中dual什么意思,oracle中dual详解
  18. 【自定义控件】仿支付宝支付动画
  19. 长安大学计算机考研资料汇总
  20. Inside Raccoon Stealer V2

热门文章

  1. 解决下载软件老是附带流氓软件的下载问题
  2. 修改若依微服务版遇到的的问题
  3. UOS Deepin 安装 flatpak
  4. 鸽巢原理(初识)(纯算法)
  5. 中国大学MOOC北京大学唐大仕老师《Java程序设计》源码分享
  6. 如何下载并安装VMware虚拟机。
  7. html 中的 css 的强制换行与不换行文本
  8. 如何做好IT战略规划与IT咨询!
  9. 使用windows引导的ubuntu双操作系统
  10. 在数据库中能不能像用excel那样直接填表保存进数据库,而不是用SQL语句