프로세스/쓰레드별 정확한 CPU 사용율 측정 방법

slashdot의 이미지

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를 사용하는지 정보가...

ydhoney의 이미지

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 파일을 참조하세요.

slashdot의 이미지


예를들어..
+-java---java---44*[{java}]
¦ +-35*[{java}]

위의 자바 쓰레드가 어떤 CPU를 쓰고 있는지 정보를...

ydhoney의 이미지

명령어 쳐 보셨나요?

slashdot의 이미지

프로세스에 대한 CPU 정보는 나옵니다만.. 쓰레드에 관한건.

ydhoney의 이미지

리눅스는 쓰레드도 프로세스처럼 표시할텐데요?

혹시 ps 결과에 쓰레드 단위로 표시되지 않습니까?

pstree에 나온 java thread 갯수등의 결과와 ps -ef 나 ps auxwww 등의 결과를 비교해보면 좋을 것 같습니다.

ps 결과에 쓰레드별로 표시되지 않는다면 뭔가 다른 방법으로 생각해 보아야 하겠습니다만, 지금껏 자바 쓰레드를 리눅스상에서 프로세스처럼 표기되지 않은것을 본 바가 없어서 잘 모르겠네요.

yeilho의 이미지

htop 사용해보세요.
각 task별로 정보를 보여주니 쓰레드로 볼수 있고 setup에서 CPU 컬럼을 선택하시면 원하시는 정보를 볼수 있을거 같네요. ^^

Linux rules!!!

Linux rules!!!

slashdot의 이미지

와우 ~~~ -_-)b

감사합니다.

익명 사용자의 이미지

thread별로 확인하기 위해서는 secretfrominternet 님이 제안하신 방법을 다음과 같이 조금 바꾸니 필요한 정보가 모두 출력되네요.
CentOS 6.4 기준입니다.

ps -AT -o psr,pid,spid,ppid,c,stime,tty,time,cmd

-AT : 쓰레드 단위까지 (-T) 모두 출력 (-A)
spid : Thread의 pid.

댓글 달기

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
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.