[참고] i/o 모니터링 관련 iostat
iostat 를 이용하여 i/o 를 모니터링할 수 있습니다.
io 관련한 모니터링 자료는 /proc/stat 에서 disk_io에 해당합니다. 그런데 io 관련한 자료가 별로 없어서 이를 해석하는게 헷갈립니다.
커널 문서에도 이에 대한 내용은 업고 아마도 소스를 보아야 정확한 이해가 갈겁니다. 구글에서 이에 대한 비슷한 질문이 있었지만 커널 소스를 가지고 설명하더군요. 한번 구글에서 찾아보세요.
# 참고자료
http://list.ftech.net/pipermail/gllug/2002-August/025225.html
http://tunelinux.pe.kr/tune/tunning-pse/pse-01.html
http://tunelinux.pe.kr/wikix/index.php?display=SystemMonitoring
/proc/stat 는 부팅이후부터 누적된 값을 보여줍니다.
$ cat /proc/stat | grep disk
disk_io: (3,0):(697057,40796,705670,656261,10945166) (3,1):(30,22,266,8,72)
3,0 : major/minor (/dev/hda 3,1 은 /dev/hdb)
뒤에 다섯개의 숫자가 나옵니다.
697057,40796,705670,656261,10945166
제일 앞의 숫자는 뭔지 잘 이해가 가지 않습니다. 그럼 뒤의 나머지 네개는?
read-requests,read-sectors,write-requests,write-sectors
The number of read requests / The total number of blocks read / The number of write requests / The total number of blocks written
여기서 블럭의 단위는 512B ytes 입니다.
# iostat -td 1
Time: 10:24:44 PM
Device: tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn
dev3-0 7.06 7.65 110.98 767678 11143682
dev3-1 0.00 0.00 0.00 266 72
Time: 10:24:45 PM
Device: tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn
dev3-0 0.00 0.00 0.00 0 0
dev3-1 0.00 0.00 0.00 0 0
# iostat -td 1 -x /dev/hda
Linux 2.4.20-20.7BOOT (db.ldskorea.co.kr) 11/30/2003
Time: 10:26:07 PM
Device: rrqm/s wrqm/s r/s w/s rsec/s wsec/s rkB/s wkB/s avgrq-sz avgqu-sz await svctm %util
/dev/hda 0.51 7.27 0.45 6.06 7.64 110.98 3.82 55.49 18.22 1.54 248.57 222.09 14.46
Time: 10:26:08 PM
Device: rrqm/s wrqm/s r/s w/s rsec/s wsec/s rkB/s wkB/s avgrq-sz avgqu-sz await svctm %util
/dev/hda 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 42949642.96 0.00 0.00 100.00
Time: 10:26:09 PM
Device: rrqm/s wrqm/s r/s w/s rsec/s wsec/s rkB/s wkB/s avgrq-sz avgqu-sz await svctm %util
/dev/hda 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 42949642.96 0.00 0.00 100.00
참고로 제일 처음 나오는 값은 부팅이후의 값이므로 무시하고 그 다음줄부터 보아야 합니다.
여기서 read request, write request 를 합하여 초당 나눈것이 tps 입니다. 초당 io 요청을 얼마나 많이 했나를 볼 수 있습니다.
중요한것은 다음과 같겠지요.
초당 얼마나 많은 i/o 요청을 하는가 : tps, r/s, w/s - 전체, read, write io request
초당 전송량 : r/w 전송양입니다. -x 옵션이 없을때는 블락기준이며(Blk_read/s Blk_wrtn/s) 이를 byte 로 바꾸러면 512 byte 를 곱하면 됩니다. -x 옵션이 있으면 바이트로 나옵니다. (rkB/s, wkB/s )
r/w 비율 : i/o request, 전송량에서 read 와 write 비율을 보면 주로 읽기중심인지 쓰기중심인지 알 수 있을 것입니다.
댓글 달기