iotop e iostat discordam

6

Estou tentando entender o que está acontecendo com os discos do meu servidor. Ele está executando o Ubuntu 12.04LTS e estou acostumado a usar iostat para saber quando o disco é o gargalo. Mas iostat -xd me parece que o disco está bem ocioso:

Linux 3.2.0-41-generic (loki)   07/05/2013  _x86_64_    (8 CPU)

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.16     1.23    0.69    1.49     9.94    37.03    43.05     0.52  239.02   14.16  343.06   3.65   0.80
sdb               0.00     0.00    0.00    0.00     0.00     0.00     8.10     0.00    0.25    0.25    0.00   0.25   0.00
dm-0              0.00     0.00    0.82    2.70     9.92    37.03    26.67     0.72  203.84   16.80  260.64   2.27   0.80
dm-1              0.00     0.00    0.00    0.00     0.00     0.00     7.99     0.00  198.63    9.33 1232.65  13.97   0.00
dm-2              0.00     0.00    0.00    0.00     0.00     0.00     7.99     0.00  497.11   14.27 1858.12  20.96   0.00

Considerando que iotop conta uma imagem muito diferente:

Total DISK READ:      31.84 M/s | Total DISK WRITE:      19.55 M/s
  TID  PRIO  USER     DISK READ  DISK WRITE  SWAPIN     IO>    COMMAND                                                                                     
27472 be/4 mongodb    31.35 M/s    3.92 K/s  0.00 % 46.56 % mongod --config /etc/mongodb.conf
  318 be/3 root        0.00 B/s   94.06 K/s  0.00 % 44.52 % [jbd2/dm-0-8]
 1493 be/4 mongodb     0.00 B/s   48.88 M/s  0.00 %  9.13 % mongod --config /etc/mongodb.conf
    1 be/4 root        0.00 B/s    0.00 B/s  0.00 %  0.00 % init
    2 be/4 root        0.00 B/s    0.00 B/s  0.00 %  0.00 % [kthreadd]
    3 be/4 root        0.00 B/s    0.00 B/s  0.00 %  0.00 % [ksoftirqd/0]
    6 rt/4 root        0.00 B/s    0.00 B/s  0.00 %  0.00 % [migration/0]
    7 rt/4 root        0.00 B/s    0.00 B/s  0.00 %  0.00 % [watchdog/0]

com mongod escrevendo dezenas de megabytes por segundo.

De onde vem a discrepância e em que devo acreditar?

    
por Leopd 05.07.2013 / 21:20

1 resposta

10

iostat -xd fornecerá as médias desde a última redefinição do contador (normalmente a última reinicialização do sistema), enquanto iotop produz médias do último segundo. Se você quiser resultados comparáveis, acrescente um intervalo de tempo de atualização à sua chamada iostat , como

iostat -xdm 5

para média ao longo de um período de tempo de 5 segundos. Você ainda precisaria jogar fora as primeiras linhas de saída (como seria a média do último reset do contador) e aguardar o segundo conjunto de linhas de saída para ver as médias "atuais".

    
por 05.07.2013 / 22:05