프로세스의 I/O 점유율(?)을 볼 수 있을까요?

훌륭한녀석의 이미지

시스템에서 작동중인 프로세스의 I/O 상태를 알고 싶을때 사용하는 프로그램등이 있을까요? top에서는 나타나지 않는듯 한데, 추천 부탁드립니다.

I/O 작업이(주로 디스크입니다) 많은 작업을 알아내고픈게 지금의 상태입니다.

bugiii의 이미지

프비라면 iostat

문태준의 이미지

실은 i/o 관련하여 모니터링툴이 빈약한건 사실입니다. iostat는 sysstat 패키지에 들어있습니다. (여기에는 sar 등이 같이 있음)

i/o stat 관련해서는 간단히 정리한 문서가 있습니다.
http://tunelinux.pe.kr/zboard/view.php?id=tip&page=1&no=57

sar 관련해서는
http://tunelinux.pe.kr/wikix/index.php?display=SystemMonitoring
http://tunelinux.pe.kr/wikix/index.php?display=Sar

===============================================
iostat 를 이용하여 i/o 를 모니터링할 수 있습니다.

io 관련한 모니터링 자료는 /proc/stat 에서 disk_io에 해당합니다. 그런데 io 관련한 자료가 별로 없어서 이를 해석하는게 헷갈립니다.
커널 문서에도 이에 대한 내용은 업고 아마도 소스를 보아야 정확한 이해가 갈겁니다. 구글에서 이에 대한 비슷한 질문이 있었지만 커널 소스를 가지고 설명하더군요. 한번 구글에서 찾아보세요.

http://list.ftech.net/pipermail/gllug/2002-August/025225.html

/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 비율을 보면 주로 읽기중심인지 쓰기중심인지 알 수 있을 것입니다.

---------------------------
문태준
http://groups.google.co.kr/group/sysadminstudy 시스템어드민 공부모임
http://tunelinux.pe.kr
http://database.sarang.net

문태준의 이미지

제목 그대로입니다. vmstat 에서 block되는 i/o가 있는지, 다른 모니터링값들을 보면서 판단해보아야합니다.

---------------------------
문태준
http://groups.google.co.kr/group/sysadminstudy 시스템어드민 공부모임
http://tunelinux.pe.kr
http://database.sarang.net

다즐링의 이미지

io 작업이 많다는게 무슨뜻인가요?

열린 파일이 많다는 것인지

파일을 많이 읽고 쓴다는것인지..

훌륭한녀석 wrote:
시스템에서 작동중인 프로세스의 I/O 상태를 알고 싶을때 사용하는 프로그램등이 있을까요? top에서는 나타나지 않는듯 한데, 추천 부탁드립니다.

I/O 작업이(주로 디스크입니다) 많은 작업을 알아내고픈게 지금의 상태입니다.

------------------------------------------------------------------------------------------------
Life is in 다즐링

훌륭한녀석의 이미지

다즐링 wrote:
io 작업이 많다는게 무슨뜻인가요?

열린 파일이 많다는 것인지

파일을 많이 읽고 쓴다는것인지..

훌륭한녀석 wrote:
시스템에서 작동중인 프로세스의 I/O 상태를 알고 싶을때 사용하는 프로그램등이 있을까요? top에서는 나타나지 않는듯 한데, 추천 부탁드립니다.

I/O 작업이(주로 디스크입니다) 많은 작업을 알아내고픈게 지금의 상태입니다.

제 말이 좀 애매했던 모양이군요. 쓰면서도 그러리라 생각했습니다.

제가 의도한 바는 "파일을 많이 읽고 쓴다."라고 해야 할것같습니다.
그리고 iostat에 관한 내용은 제가 좀 더 살펴봐야할것 같네요. 아직까지는 초보라.. :oops: 답변 감사합니다.~

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.