Как определить, ищет ли диск?

16

Я могу использовать различные инструменты для измерения объема дискового ввода-вывода, который в данный момент проходит через систему (например, iotopи iostat), но мне любопытно, можно ли легко определить, ищет ли диск много с небольшим количеством I / O.

Я знаю, возможно ли извлечь эту информацию, используя, blktraceа затем расшифровать ее, bttно это несколько громоздко, и я надеялся, что была более простая альтернатива?

Гиероид Мерфи
источник
4
Поднесите ухо близко к диску? :)
Тердон
2
Разве низкий коэффициент не должен (rkB/s + wkB/s)/%utilозначать, что диск ищет (в iostat -x)?
Марко
1
Вам нужен инструмент, который показывает это в прямом эфире, или вы хотите посмотреть на данные за определенный период времени?
SLM
1
AFAIK , kernel.org/doc/Documentation/iostats.txt - единственная статистика, поддерживаемая ядром, поэтому я не ожидаю, что вы найдете лучше, чем blktrace.
Стефан Шазелас

Ответы:

4

Соотношение (rkB/s + wkB/s)/%utilна iostat -xвыходе должно дать вам некоторое представление о том :

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

Я не уверен, насколько точно это соотношение соответствует поиску диска. Но идея состоит в том, что, если диск занят и не имеет высокой пропускной способности, он, вероятно, ищет. Однако это не гарантировано. Сломанные диски иногда показывают высокую загрузку и почти не имеют пропускной способности. Но это как минимум показатель.

Вы также можете указать номер iostat (например, iostat -x 5 указать ), чтобы указать интервал обновления. Таким образом, вы можете контролировать непрерывно.

Marco
источник
Предположительно, многие запросы на чтение в паре с низким rkB / s будут свидетельствовать о такой ситуации
Gearoid Murphy
8

Не уверен, если вы ищете инструменты, которые отображают этот тип информации в режиме реального времени или в течение определенного периода времени, но вот 2 инструмента, которые показывают аспекты доступа к диску в реальном времени.

Nmon

Вы вызываете это так nmon. Затем, как только он открывается, вы нажимаете j(Файловые системы), а затем d(Графики дискового ввода-вывода D = Статистика). Смотрите встроенную справку ( 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                                                                │
│──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────│

Еще один инструмент, с которым я столкнулся, - это, по крайней мере, просмотр в реальном времени дискового ввода-вывода 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

В частности, эти строки, которые показывают активность LVM и 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

Если вам интересны данные за определенный период времени, iostatэто, вероятно, ваш лучший вариант, заключенный в сценарий. Вы можете избавиться от вывода об использовании, чтобы с ним было легче иметь дело:

$ 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

Прямо из ядра

Этот блок кода (bash) покажет вам обработанные операции чтения ввода-вывода непосредственно из ядра.

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

источник: /server//a/525248/2518

Информация также может быть получена из /sys/block/sda/statили /proc/diskstatsв ситуациях, когда вы не можете или не хотите устанавливать какие-либо инструменты.

Ссылки

SLM
источник
Спасибо за подробный ответ, но предоставленные вами показатели все еще ориентированы на ввод-вывод, в идеале я хотел бы видеть активность поиска диска независимо от пропускной способности ввода-вывода
Gearoid Murphy
@GearoidMurphy - я не видел способа получить этот тип телеметрических данных о доступе к диску за пределами ввода-вывода.
СЛМ
Я думаю, что Марко упомянул об этом в комментарии выше, решение было бы посмотреть на соотношение транзакций на диске к фактическому объему чтения / записи данных.
Героид Мерфи
1
@GearoidMurphy - да, именно поэтому я попросил уточнить в комментариях, хотите ли вы тип решения в реальном времени или тип периода времени. Если вы найдете подходящее решение, я напишу его в качестве ответа и приму его. Там не было много, когда вы искали ваш конкретный уклон по этому вопросу.
SLM