Jak wykryć, czy dysk szuka?


16

Mogę używać różnych narzędzi do mierzenia objętości we / wy dysku przepływającego obecnie przez system (np. iotopI iostat), ale jestem ciekawy, czy można łatwo wykryć, czy dysk szuka dużo przy niewielkiej ilości I / O.

Wiem, że możliwe jest wyodrębnienie tych informacji za pomocą, blktracea następnie ich odkodowanie za pomocą, bttale są one nieco nieporęczne i miałem nadzieję, że istnieje prostsza alternatywa?


4
Przyłożyć ucho do napędu? :)
terdon

2
Czy niski współczynnik nie powinien (rkB/s + wkB/s)/%utiloznaczać, że dysk szuka (wchodzi iostat -x)?
Marco,

1
Czy chcesz narzędzie, które pokazuje to na żywo, czy chcesz przeglądać dane w danym okresie czasu?
slm

1
AFAIK, kernel.org/doc/Documentation/iostats.txt to jedyne statystyki obsługiwane przez jądro, więc nie oczekuję, że znajdziesz coś lepszego niż blktrace.
Stéphane Chazelas

Odpowiedzi:


4

Stosunek (rkB/s + wkB/s)/%utilz iostat -xwyjściem powinno dać pewne wyobrażenie:

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

Nie jestem pewien, jak dokładnie ten stosunek odpowiada wyszukiwaniu na dysku. Ale chodzi o to, że jeśli dysk jest zajęty i nie ma dużej przepustowości, prawdopodobnie szuka. Nie jest to jednak gwarantowane. Zepsute dyski czasami wykazują duże wykorzystanie i prawie nie mają przepustowości. Ale to przynajmniej wskaźnik.

Możesz także podać numer iostatowi (np. iostat -x 5), Aby określić interwał aktualizacji. W ten sposób możesz stale monitorować.


Przypuszczalnie wiele żądań odczytu sparowanych z niskim rkB / s wskazywałoby na taką sytuację
Gearoid Murphy

8

Nie jestem pewien, czy szukasz narzędzi, które wyświetlają tego rodzaju informacje w czasie rzeczywistym lub w określonym czasie, ale oto 2 narzędzia, które pokazują aspekty dostępu do dysku w czasie rzeczywistym.

nie

Wywołać to uczucie tak nmon. Następnie, gdy jest otwarty, uderzasz w j(Systemy plików), a następnie d(Wykresy We / Wy dysku D = Stats). Więcej informacji można znaleźć we wbudowanej pomocy ( h).

$ 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                                                                │
│──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────│

Innym narzędziem, z którym się zetknąłem, jest przynajmniej podgląd na żywo operacji we / wy dysku 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

W szczególności te wiersze, które pokazują aktywność LVM i DSK:

    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

Jeśli interesują Cię dane przez pewien czas, iostatjest to prawdopodobnie najlepsza opcja, zapakowana w skrypt. Możesz pozbyć się wyników wykorzystania, aby łatwiej było sobie poradzić z:

$ 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

Bezpośrednio z jądra

Ten blok kodu (bash) pokaże przetworzone operacje we / wy, bezpośrednio z jądra.

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

źródło: /server//a/525248/2518

Informacje można również uzyskać z jednego /sys/block/sda/statlub /proc/diskstatsw sytuacjach, w których nie można lub nie chcesz instalować żadnych narzędzi.

Bibliografia


Dziękuję za szczegółową odpowiedź, ale podane przez Ciebie wskaźniki są nadal skoncentrowane na
operacjach

@GearoidMurphy - Nie widziałem sposobu, aby uzyskać tego rodzaju dane telemetryczne dotyczące dostępu do dysku poza I / O.
slm

Myślę, że Marco trafił na to w powyższym komentarzu, rozwiązaniem byłoby przyjrzenie się stosunkowi transakcji dyskowych do rzeczywistej ilości odczytanych / zapisanych danych.
Gearoid Murphy

1
@GearoidMurphy - tak, dlatego poprosiłem o wyjaśnienie w komentarzach, czy chcesz typ rozwiązania w czasie rzeczywistym, czy okres. Jeśli wpadniesz na realne rozwiązanie, napiszę je jako odpowiedź i zaakceptuję. Nie było wiele, gdy szukałeś swojego szczególnego skoku w tym zakresie.
slm
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.