프로세스/쓰레드별 정확한 CPU 사용율 측정 방법
글쓴이: slashdot / 작성시간: 월, 2010/08/09 - 2:14오후
CPU 8개인 서버에서
1. 하나의 프로세스에서 20개를 Fork 한다고 하면
1-1. 이 20개의 프로세스가 각각의 8개의 CPU의 자원을 나눠서 사용하는 것인지요?
1-2. 이때 각 프로세스가 몇번째 CPU를 쓰는지 확실히 눈으로 볼수 있는 프로그램이 어떤 것이 있는지요?
2. 프로세스->(포크)->프로세스-> 별도로 I/O만 처리하기 위해 1024 개의 쓰레드를 생성하면
2-1. 하나의 프로세스에서 20개의 쓰레드를 사용하였으니 이는 다중 CPU를 사용하는 것인지요?
2-2. 이때 각 쓰레드가 몇번째 CPU를 쓰는지 확실히 눈으로 볼수 있는 프로그램이 어떤 것이 있는지요?
읽어주셔서 감사드립니다.!
추신. atop, sar... 등등의 툴은 사용해도 어떤 프로세스/쓰레드가 몇번째장 CPU를 사용하는지 정보가...
Forums:
ps -eo
ps -eo psr,uid,pid,ppid,c,stime,tty,time,cmd
이렇게 출력할 경우 ps -ef 결과에 psr만 붙인 출력결과가 됩니다.
ps man page의 psr 설명은 다음과 같습니다.
psr PSR processor that process is currently assigned to.
그리고 cpu 배분상황은 irqbalance가 어떻게 움직이느냐에 따라서 잘 알아서 합니다. 보통은..(irqbalance 서비스가 잘 돌고 있어야겠죠..)
process를 특정 core에 fix 하도록 되어있는 embeded 장비들 아니라면 말이죠.
시스템 core 배분운용 현황은 /proc/interrupts 파일을 참조하세요.
흠.........
예를들어..
+-java---java---44*[{java}]
¦ +-35*[{java}]
위의 자바 쓰레드가 어떤 CPU를 쓰고 있는지 정보를...
명령어 쳐 보셨나요?
명령어 쳐 보셨나요?
네
프로세스에 대한 CPU 정보는 나옵니다만.. 쓰레드에 관한건.
리눅스는 쓰레드도
리눅스는 쓰레드도 프로세스처럼 표시할텐데요?
혹시 ps 결과에 쓰레드 단위로 표시되지 않습니까?
pstree에 나온 java thread 갯수등의 결과와 ps -ef 나 ps auxwww 등의 결과를 비교해보면 좋을 것 같습니다.
ps 결과에 쓰레드별로 표시되지 않는다면 뭔가 다른 방법으로 생각해 보아야 하겠습니다만, 지금껏 자바 쓰레드를 리눅스상에서 프로세스처럼 표기되지 않은것을 본 바가 없어서 잘 모르겠네요.
htop 사용해보세요
htop 사용해보세요.
각 task별로 정보를 보여주니 쓰레드로 볼수 있고 setup에서 CPU 컬럼을 선택하시면 원하시는 정보를 볼수 있을거 같네요. ^^
Linux rules!!!
Linux rules!!!
yeilho 님
와우 ~~~ -_-)b
감사합니다.
thread별로 확인하기 위해서는
thread별로 확인하기 위해서는 secretfrominternet 님이 제안하신 방법을 다음과 같이 조금 바꾸니 필요한 정보가 모두 출력되네요.
CentOS 6.4 기준입니다.
ps -AT -o psr,pid,spid,ppid,c,stime,tty,time,cmd
-AT : 쓰레드 단위까지 (-T) 모두 출력 (-A)
spid : Thread의 pid.
댓글 달기