RadarURL

조회 수 1134 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

top 에서 보여주는 것 중에
cpu 정보에 보면
us, sy, ni, hi, si, wa 라는게 있던데
 이중에 ni, hi, si, wa 가 궁금합니다.
구글링 중에 찾은 것은

ni = nice
 hi = ? Probably hard interrupt
 si = ? Probably soft interrupt
 wa = IO wait

라는 이야기가 있던데
 그럼 여기서 nice 는 뭘 의미하고,
hard interrupt 와 soft interrupt 의 차이는 뭔가요?

그리고 IO wait 은 그럼 IO 를 기다리는 동안 다른 프로세스로 스케줄링을 하지 않고 그냥 해당 프로세스의 IO 를 기다린다는 건가요?
만약 그렇다면 왜 그런 비효율적인 작동을 하는거죠?(DMA 나 SCSI 가 아닌 경우 때문인가요?)



답변 :

nice는 아시다시피 유닉스에서 프로세스의 우선순위를 의미합니다. top

글쓴이: wariua 작성 일시: 토, 2006/02/25 - 1:44오전


nice는 아시다시피 유닉스에서 프로세스의 우선순위를 의미합니다. top 표시 내용 중 ni(nice)는 "기본값보다 낮은 우선순위로 사용자 공간에서 실행된 시간"을 의미합니다. 따라서 us(user)는 정확하게는 "기본값으로, 혹은 그보다 높은 우선순위로 사용자 공간에서 실행된 시간"을 의미합니다.

hi(hard interrupt)는 "순수한(?) 인터럽트 핸들러에서 사용한 시간"을 의미합니다. 하지만 인터럽트 핸들러는 수행중 다른 인터럽트를 꺼버리기 때문에 가능하면 빨리 실행을 마쳐야 합니다. 그래서 시간이 걸릴 만한 작업은 잠시 미뤄뒀다가 실행합니다. (나중에 인터럽트 처리 작업을 마저 처리하는 부분을 "bottom halves"라고 부르더군요. 인터럽트 핸들러는 "top halves"라고 부르고요.) "잠시 미뤄둔 인터럽트 처리 작업에 사용한 시간"이 바로 si(soft interrupt) 항목입니다.

wa(I/O wait)은 I/O를 기다리는 시간이 맞습니다. 어떤 프로세스가 I/O 때문에 wait 상태로 들어갈 때 즉시 실행 가능한 다른 프로세스가 있으면 그 프로세스를 실행하지만 그렇지 않은 경우는 어쩔 수 없이 I/O 대기 작업 중 하나가 완료될 때까지 대기해야 합니다. 그 때 사용한 시간이 wa입니다. 모든 프로세스가 I/O 완료가 아닌 다른 이벤트를 기다리면서 쉬고 있으면 이는 id(idle) 항목에 해당합니다.

항목들 간의 관계를 좀 정리하자면...

◦wa(I/O wait)과 id(idle)은 모두 대기 시간입니다. I/O를 기다리는 프로세스가 하나라도 있으면 wa에 카운트 되고 그렇지 않으면 id에 카운트 됩니다.
◦hi(hard interrupt)와 si(soft interrupt)를 합치면 인터럽트 처리에 쓰인 시간이 됩니다. 인터럽트 핸들러 자체에서 잠깐 쓴 시간은 hi에, 미뤄둔 처리 작업에 쓰인 시간은 si에 카운트 됩니다.
◦sy(system)는 wa,id,hi,si를 제외하고서 커널 내에서 쓰인 시간입니다. hi, si도 (그리고 더 정확하게는 wa와 id도) 커널 내의 시간이라고 할 수 있지만 sy 항목의 계산에서는 제외됩니다.
◦us(user)와 ni(nice)를 합하면 사용자 공간에서 실행된 시간입니다. 기본 우선순위보다 낮은 우선순위로 실행되느냐의 여부로 us와 ni 중 하나로 카운트 됩니다.


뱀발로... top 프로그램의 실행 결과는 결국 /proc/stat 파일의 내용을 파싱해서 뿌려주는 것입니다. 그런데 /proc/stat 출력 결과를 보면 프로세스별로 7개가 아니라 8개의 항목이 있습니다. 마지막 항목은 "steal" 항목으로 "프로세스가 비자발적으로 대기하는 데에 사용한 시간"라고 합니다... 만 현재 커널에서는(2.6.15 기준) 카운트를 하지 않고 있습니다.


-----------------------------------------------------------------------------------------------------------------------


제가 개발자 종족인지라 세부적인 내용들은 소스 코드에서 얻은 정보입니다.

글쓴이: wariua 작성 일시: 토, 2006/02/25 - 11:45오후


제가 개발자 종족인지라 세부적인 내용들은 소스 코드에서 얻은 정보입니다...;;;

본래 top의 man페이지에서 알 수 있어야 할 정보인데 거기선 찾지를 못했고, vmstat 페이지 및 proc 페이지의 "/proc/stat" 항목에서 대략적인 정보는 얻을 수 있었습니다. 인용하자면


man vmstat wrote:
us: Time spent running non-kernel code. (user time, including nice time)
sy: Time spent running kernel code. (system time)
 id: Time spent idle. Prior to Linux 2.5.41, this includes IO-wait time.
 wa: Time spent waiting for IO. Prior to Linux 2.5.41, shown as zero.


man proc wrote:
cpu 3357 0 4313 1362393
 The number of jiffies (1/100ths of a second) that the system spent in user mode, user mode with low priority (nice), system mode, and the idle task, respectively. The last value should be 100 times the second entry in the uptime pseudo-file.


 proc 페이지의 내용은 2.4.x 커널 기준인 듯 합니다.



출처 : https://kldp.org/node/65018

?

공부 게시판

공부에 도움되는 글을 올려주세요.

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
공지 [공지] 공부 게시판 입니다. 처누 2003.08.18 927819
526 데이터베이스 Oracle(오라클) 테이블 목록과 각 테이블별 레코드 건수 구하기 JaeSoo 2014.10.02 1898
525 인터넷 인터넷 URL 주소 줄이기 대표 사이트 4곳 file JaeSoo 2014.10.02 1464
524 업무 "ea."의 오용: "(몇)개"란 뜻은 없습니다. JaeSoo 2014.10.06 1312
523 유닉스/리눅스 리눅스 호스트명 변경 JaeSoo 2014.10.10 1062
522 업무 연봉제 임금자 통상임금 계산방법 JaeSoo 2014.10.10 1148
521 업무 주휴수당은 누가 받을 수 있나 JaeSoo 2014.10.10 1068
520 취미 Xbox360 글리치 와 xkey(엑키) 와사비의 차이는 어떤것일까요? JaeSoo 2014.10.13 2317
519 취미 XBOX360 모드칩 와사비 360 사용자 가이드 번역 file JaeSoo 2014.10.13 1213
518 취미 Xbox360 모드칩 Xkey 설치후 사용방법 file JaeSoo 2014.10.13 1694
517 취미 Xbox360 모드칩 Xkey 슬림 설치/구동 완벽 메뉴얼 file JaeSoo 2014.10.13 1737
516 업무 출판 인세를 다른 곳은 30%, 50%를 준다는 데요. file JaeSoo 2014.10.14 1210
» 유닉스/리눅스 리눅스 프로세스 상태 모니터링의 top 에서 ni, hi, si, wa 필드의 의미 JaeSoo 2014.10.14 1134
514 업무 Prototypin, Pilot, PoC, BMT 의 차이점 JaeSoo 2014.10.18 889
513 경제 알기쉬운 유상증자 vs 무상증자 file JaeSoo 2014.10.18 1294
512 유닉스/리눅스 [공개SW 활용 성공사례 152] KTDS – JBoss·PostgreSQL 등으로 공개SW 전환 택한 KTDS file JaeSoo 2014.10.18 1055
511 네트워크 Part I. 5세대 기가 와이파이(802.11ac) 이야기 그리고 공유기 선택가이드 file JaeSoo 2014.10.18 1004
510 네트워크 Part II. 기가와이파이(802.11ac)를 지원하는 공유기 네티스 WF2780 리뷰 file JaeSoo 2014.10.18 1408
509 유닉스/리눅스 리눅스 스케줄러 crontab 이용하기 file JaeSoo 2014.10.20 1106
508 유닉스/리눅스 Linux에서 Cron을 이용한 스케쥴러 관리 JaeSoo 2014.10.20 1518
507 유닉스/리눅스 CentOS에서 Iptables 방화벽 포트 OPEN하기 JaeSoo 2014.10.20 1370
Board Pagination Prev 1 ... 93 94 95 96 97 98 99 100 101 102 ... 124 Next
/ 124


즐겨찾기 (가족)

JAESOO's HOMEPAGE


YOUNGAE's HOMEPAGE


장여은 홈페이지


장여희 홈페이지


장여원 홈페이지


즐겨찾기 (업무)

알리카페 홀릭

숭실대 컴퓨터 통신연구실 (서창진)

말레이시아 KL Sentral 한국인 GuestHouse


즐겨찾기 (취미)

어드민아이디

유에코 사랑회

아스가르드 좋은사람/나쁜사람

JServer.kr

제이서버 메타블로그

재수 티스토리


즐겨찾기 (강의, 커뮤니티)

재수 강의 홈페이지


한소리


VTMODE.COM


숭실대 인공지능학과


숭실대 통신연구실


베너