Wie erkenne ich, ob eine Festplatte gesucht wird?


16

Ich kann eine Vielzahl von Tools verwenden, um das Volumen der aktuell durch das System fließenden Festplatten-E / A zu messen (z. B. iotopund iostat). Ich bin jedoch gespannt, ob es möglich ist, auf einfache Weise zu erkennen, ob eine Festplatte mit nur einer geringen Menge an Festplatten viel sucht I / O.

Ich weiß, dass es möglich ist, diese Informationen mit zu extrahieren blktraceund sie dann mit zu dekodieren, bttaber diese sind etwas unhandlich und ich hatte gehofft, dass es eine einfachere Alternative gibt.


4
Legen Sie Ihr Ohr nah an Ihr Laufwerk? :)
terdon

2
Sollte ein niedriges Verhältnis nicht (rkB/s + wkB/s)/%utilbedeuten, dass die Festplatte sucht (in iostat -x)?
Marco

1
Möchten Sie ein Tool, das dies live zeigt, oder möchten Sie die Daten für einen bestimmten Zeitraum anzeigen?
SLM

1
AFAIK, kernel.org/doc/Documentation/iostats.txt sind die einzigen Statistiken, die vom Kernel verwaltet werden. Ich gehe also nicht davon aus, dass Sie bessere als blktrace finden.
Stéphane Chazelas

Antworten:


4

Das Verhältnis (rkB/s + wkB/s)/%utilder iostat -xAusgabe sollte Ihnen einen Einblick geben:

Device:  rrqm/s wrqm/s   r/s   w/s  rkB/s  wkB/s avgrq-sz avgqu-sz await r_await w_await  svctm  %util
sda        0.04   3.65  7.16  6.37 150.82 212.38    53.71     0.03  1.99    0.82    3.31   0.76   1.03

Ich bin mir nicht sicher, wie genau dieses Verhältnis der Festplattensuche entspricht. Aber die Idee ist, dass, wenn die Festplatte ausgelastet ist und keinen hohen Durchsatz hat, sie wahrscheinlich sucht. Es ist jedoch nicht garantiert. Defekte Festplatten weisen manchmal eine hohe Auslastung auf und weisen fast keinen Durchsatz auf. Aber es ist zumindest ein Indikator.

Sie können iostat auch eine Nummer zuweisen (z. B. iostat -x 5), um das Aktualisierungsintervall festzulegen. Auf diese Weise können Sie kontinuierlich überwachen.


Vermutlich deuten viele Leseanfragen, die mit niedrigen rkB / s gepaart sind, auf eine solche Situation hin
Gearoid Murphy,

8

Sie sind sich nicht sicher, ob Sie nach Tools suchen, die diese Art von Informationen in Echtzeit oder über einen bestimmten Zeitraum hinweg anzeigen. Im Folgenden finden Sie zwei Tools, die die Echtzeitaspekte des Datenträgers anzeigen, auf den zugegriffen wird.

nmon

Sie rufen es gerne so, nmon. Sobald es geöffnet ist, jdrückst du auf (Dateisysteme), gefolgt von d(Disk I / O Graphs D = Stats). hWeitere Informationen finden Sie in der integrierten Hilfe ( ).

$ nmon
┌nmon─13g─────────────────────Hostname=manny────────Refresh= 2secs ───11:15.32─────────────────────────────────────────────────────┐
│ Filesystems ─────────────────────────────────────────────────────────────────────────────────────────────────────────────────────│
│Filesystem            SizeMB  FreeMB %Used Type     MountPoint                                                                    │
│v/mapper/ubuntu-root 465389.0 457483.9   1.7 ext4     /                                                                           │
│/proc                                      proc     not a real filesystem                                                         │
│/sys                                       sysfs    not a real filesystem                                                         │
│/sys/fs/fuse/connections                   fusectl  not a real filesystem                                                         │
│/sys/kernel/debug                          debugfs  not mounted                                                                   │
│/sys/kernel/security                       security not a real filesystem                                                         │
│/dev                                       devtmpfs not a real filesystem                                                         │
│/dev/pts                                   devpts   not a real filesystem                                                         │
│tmpfs                  740.5   739.4   0.1 tmpfs    /run                                                                          │
│none                     5.0     5.0   0.0 tmpfs    /run/lock                                                                     │
│none                  1851.2  1849.8   0.1 tmpfs    /run/shm                                                                      │
│none                   100.0    99.9   0.1 tmpfs    /run/user                                                                     │
│/dev/sda1              910.9   606.5  33.4 ext2     /boot                                                                         │
│/run/rpc_pipefs                            rpc_pipe fstatfs returned zero blocks!!                                                │
│/run/user/emma/gvfs                        fuse.gvf not mounted                                                                   │
│/run/user/emily/gvfs                       fuse.gvf not mounted                                                                   │
│ Disk I/O ──/proc/diskstats────mostly in KB/s─────Warning:contains duplicates─────────────────────────────────────────────────────│
│DiskName Busy  Read WriteMB|0          |25         |50          |75       100|                                                    │
│sda      100%    0.0   66.4|RWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWW>                                                    │
│sda1       0%    0.0    0.0|>                                                |                                                    │
│sda2       0%    0.0    0.0|>                                                |                                                    │
│sda5     100%    0.0   66.4|RWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWW>                                                    │
│dm-0     100%    0.0   48.0|RWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWW>                                                    │
│dm-1       0%    0.0    0.0|                     >                           |                                                    │
│Totals Read-MB/s=0.0      Writes-MB/s=180.9    Transfers/sec=363.2                                                                │
│──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────│

Ein weiteres Werkzeug , das ich über die gekommen sind , hat zumindest eine Live - Ansicht von Disk - I / O ist atop.

$ atop
ATOP - grinchy                           2013/08/23  11:10:58                           ------                           10s elapsed
PRC | sys    2.18s  | user  26.26s  | #proc    315  | #trun  5 |  #tslpi   764 |  #tslpu     1 |  #zombie    0 |  #exit  1 |
CPU | sys      22%  | user    264%  | irq       0%  | idle    110% |  wait      4% |  guest     0% |  curf 1.20GHz |  curscal  44% |
cpu | sys       5%  | user     76%  | irq       0%  | idle     19% |  cpu003 w  0% |  guest     0% |  curf 1.20GHz |  curscal  44% |
cpu | sys       5%  | user     67%  | irq       0%  | idle     26% |  cpu001 w  2% |  guest     0% |  curf 1.20GHz |  curscal  44% |
cpu | sys       5%  | user     62%  | irq       0%  | idle     31% |  cpu000 w  1% |  guest     0% |  curf 1.20GHz |  curscal  44% |
cpu | sys   7%  | user     58%  | irq   0%  | idle     34% |  cpu002 w  1% |  guest     0% |  curf 1.20GHz |  curscal  44% |
CPL | avg1    3.83  | avg5    4.59  | avg15   4.76  |              |  csw    54101 |  intr   45315 |               |  numcpu     4 |
MEM | tot     7.6G  | free  194.3M  | cache 495.5M  | dirty   2.7M |  buff   38.9M |  slab   86.7M |               |               |
SWP | tot     5.7G  | free    5.5G  |               |              |               |               |  vmcom  12.4G |  vmlim   9.5G |
LVM | nchy-lv_home  | busy     11%  | read       1  | write    524 |  KiB/w      3 |  MBr/s   0.00 |  MBw/s   0.20 |  avio 2.05 ms |
LVM | nchy-lv_root  | busy      1%  | read       0  | write      7 |  KiB/w  4 |  MBr/s   0.00 |  MBw/s   0.00 |  avio 9.00 ms |
DSK |          sda  | busy     11%  | read       1  | write    109 |  KiB/w 19 |  MBr/s   0.00 |  MBw/s   0.20 |  avio 10.3 ms |
NET | transport     | tcpi  72  | tcpo     118  | udpi      15 |  udpo   5 |  tcpao     11 |  tcppo      0 |  tcprs      0 |
NET | network       | ipi       87  | ipo      123  | ipfrw      0 |  deliv     87 |               |  icmpi      0 |  icmpo      0 |
NET | wlan0   ----  | pcki      88  | pcko     123  | si   34 Kbps |  so   19 Kbps |  erri       0 |  erro       0 |  drpo       0 |

  PID  RUID       EUID       THR    SYSCPU    USRCPU   VGROW    RGROW    RDDSK   WRDSK   ST   EXC  S   CPUNR    CPU  CMD         1/4
 3649  saml       saml        34     0.33s    11.98s      0K    1752K       4K   2828K   --     -  R       2   122%  chrome
10399  saml       saml         4     0.14s     3.08s   5120K   -12.8M       0K      0K   --     -  S       2    32%  chrome

Insbesondere diese Zeilen, in denen die LVM- und DSK-Aktivität angezeigt wird:

    LVM | nchy-lv_home  | busy     11%  | read       1  | write    524 |  KiB/w      3 |  MBr/s   0.00 |  MBw/s   0.20 |  avio 2.05 ms |
    LVM | nchy-lv_root  | busy      1%  | read       0  | write      7 |  KiB/w  4 |  MBr/s   0.00 |  MBw/s   0.00 |  avio 9.00 ms |
    DSK |          sda  | busy     11%  | read       1  | write    109 |  KiB/w 19 |  MBr/s   0.00 |  MBw/s   0.20 |  avio 10.3 ms |

iostat

Wenn Sie sich über einen bestimmten Zeitraum für die Daten interessieren, iostatist dies wahrscheinlich die beste Option, die Sie in ein Skript eingebunden haben. Sie können die Auslastungsausgaben loswerden, damit Sie leichter damit umgehen können:

$ iostat -dx /dev/sda 5
Linux 2.6.35.14-106.fc14.x86_64 (grinchy)   08/23/2013  _x86_64_    (4 CPU)

Device:         rrqm/s   wrqm/s     r/s     w/s   rsec/s   wsec/s avgrq-sz avgqu-sz   await  svctm  %util
sda               1.82    96.60    3.84   20.68   122.26   891.99    41.36     0.46   18.77   7.35  18.01

Device:         rrqm/s   wrqm/s     r/s     w/s   rsec/s   wsec/s avgrq-sz avgqu-sz   await  svctm  %util
sda               0.00    26.20    1.60   24.60    17.60   350.40    14.05     0.31   11.95   8.84  23.16

Direkt aus dem Kernel

Dieser Codeblock (Bash) zeigt Ihnen die verarbeiteten Lese-E / A direkt vom Kernel.

OLD=`awk '{print $1}' /sys/block/sda/stat` # First field is number of read I/Os processed
DT=1
for ii in `seq 1 10`
do
    sleep $DT
    NEW=`awk '{print $1}' /sys/block/sda/stat`
    echo $((($NEW-$OLD)/$DT))
    OLD=$NEW
done

Quelle: /server//a/525248/2518

Die Informationen können auch von beiden gehabt werden /sys/block/sda/statoder /proc/diskstatsin Situationen , in denen Sie nicht können oder wollen keine Tools installieren.

Verweise


Vielen Dank für die ausführliche Antwort, aber die von Ihnen bereitgestellten Metriken sind immer noch auf E / A konzentriert. Im Idealfall würde ich gerne sehen, dass die Aktivität der Datenträgersuche unabhängig vom E / A-Durchsatz erfolgt
Gearoid Murphy,

@GearoidMurphy - Ich habe keine Möglichkeit gefunden, diese Art von Telemetriedaten über Datenträgerzugriffe außerhalb von E / A abzurufen.
SLM

Ich denke, Marco hat es in einem Kommentar oben angesprochen. Die Lösung wäre, das Verhältnis von Festplattentransaktionen zum tatsächlichen gelesenen / geschriebenen Datenvolumen zu betrachten.
Gearoid Murphy

1
@GearoidMurphy - ja, deshalb habe ich in den Kommentaren um Klärung gebeten, ob Sie eine Lösung in Echtzeit oder einen Zeitraum möchten. Wenn Sie eine praktikable Lösung finden, schreibe ich sie als Antwort auf und akzeptiere sie. Es gab nicht viel bei der Suche nach Ihrer besonderen Neigung dazu.
SLM
Durch die Nutzung unserer Website bestätigen Sie, dass Sie unsere Cookie-Richtlinie und Datenschutzrichtlinie gelesen und verstanden haben.
Licensed under cc by-sa 3.0 with attribution required.