Zoeken op website

7 'dmesg'-opdrachten voor het oplossen van problemen en het verzamelen van informatie over Linux-systemen


Met het commando ‘dmesg’ worden de berichten uit de kernelringbuffer weergegeven. Een systeem passeert meerdere runlevels van waaruit we veel informatie kunnen krijgen, zoals systeemarchitectuur, CPU, aangesloten apparaat, RAM enz. Wanneer de computer opstart, wordt een kernel (kern van een besturingssysteem) in het geheugen geladen. Gedurende die periode worden er een aantal berichten weergegeven waarin we hardwareapparaten kunnen zien die door de kernel zijn gedetecteerd.

Lees ook: 10 Linux-opdrachten om systeem- en hardware-informatie te verzamelen

De berichten zijn erg belangrijk voor het diagnosticeren van het doel in het geval van een apparaatstoring. Wanneer we een hardwareapparaat op het systeem aansluiten of loskoppelen, komen we met behulp van de dmesg-opdracht direct te weten dat er gedetecteerde of losgekoppelde informatie is. De opdracht dmesg is beschikbaar op de meeste op Linux en Unix gebaseerde besturingssystemen.

Laten we wat licht werpen op de meest bekende tool genaamd ‘dmesg’-opdracht met hun praktische voorbeelden, zoals hieronder besproken. De exacte syntaxis van dmesg is als volgt.

dmseg [options...]

1. Maak een lijst van alle geladen stuurprogramma's in Kernel

We kunnen hulpmiddelen voor tekstmanipulatie gebruiken, bijvoorbeeld 'meer', 'staart', 'minder' of 'grep ' met het dmesg-commando. Omdat de uitvoer van het dmesg-logboek niet op een enkele pagina past, zal het gebruik van dmesg met het commando pipe more or less logs op een enkele pagina weergeven.

[[email  ~]# dmesg | more
[[email  ~]# dmesg | less
Voorbeelduitvoer
[    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
.....

Lees ook: Beheer Linux-bestanden effectief met de commando's head, tail en cat

2. Maak een lijst van alle gedetecteerde apparaten

Om te ontdekken welke harde schijven door de kernel zijn gedetecteerd, kunt u zoeken op het trefwoord “sda” samen met “grep”, zoals hieronder weergegeven.

[[email  ~]# 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)

OPMERKING: De ‘sda’ eerste SATA-harde schijf, ‘sdb’ is de tweede SATA-harde schijf enzovoort. Zoek met ‘hda’ of ‘hdb’ in het geval van een IDE-harde schijf.

3. Druk alleen de eerste 20 regels met uitvoer af

De ‘kop’ samen met dmesg zal startlijnen tonen, d.w.z. ‘dmesg | head -20’ print slechts 20 regels vanaf het startpunt.

[[email  ~]# 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. Druk alleen de laatste 20 regels met uitvoer af

De ‘tail’ samen met de opdracht dmesg zal slechts 20 laatste regels afdrukken, dit is handig als we een verwijderbaar apparaat plaatsen.

[[email  ~]# 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. Zoek naar gedetecteerd apparaat of specifieke string

Het is moeilijk om een bepaalde string te doorzoeken vanwege de lengte van de dmesg-uitvoer. Filter dus de regels met tekenreeksen als 'usb' 'dma' 'tty' en 'geheugen ' enz. De optie '-i' instrueert het grep-commando om de hoofdletter (hoofdletters of kleine letters) te negeren.

[[email  log]# dmesg | grep -i usb
[[email  log]# dmesg | grep -i dma
[[email  log]# dmesg | grep -i tty
[[email  log]# dmesg | grep -i memory
Voorbeelduitvoer
[    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. Wis dmesg-bufferlogboeken

Ja, we kunnen dmesg-logboeken indien nodig wissen met het onderstaande commando. Het zal de berichtlogboeken van de dmesg ringbuffer wissen totdat u de onderstaande opdracht uitvoert. U kunt nog steeds logbestanden bekijken die zijn opgeslagen in ‘/var/log/dmesg’ bestanden. Als u een apparaat aansluit, wordt dmesg-uitvoer gegenereerd.

[[email  log]# dmesg -c

7. Dmesg in realtime monitoren

Sommige distributies staan ook het commando ‘tail -f /var/log/dmesg’ toe voor realtime dmesg-monitoring.

[[email  log]# watch "dmesg | tail -20"

Conclusie: Het dmesg-commando is nuttig omdat dmesg alle systeemwijzigingen registreert die in realtime zijn uitgevoerd of plaatsvinden. Zoals altijd kun je dmesg manen voor meer informatie.