<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/">
  <channel>
    <title>Top on Chanyeol Dev</title>
    <link>https://chanyeols.com/tags/top/</link>
    <description>Recent content in Top on Chanyeol Dev</description>
    <generator>Hugo</generator>
    <language>ko-kr</language>
    <lastBuildDate>Thu, 23 Apr 2026 00:00:00 +0000</lastBuildDate>
    <atom:link href="https://chanyeols.com/tags/top/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>Linux 성능 튜닝 트러블슈팅: top, iostat, vmstat로 문제 해결</title>
      <link>https://chanyeols.com/posts/linux-server-performance-monitoring-troubleshooting-with-top-iostat-vmstat/</link>
      <pubDate>Thu, 23 Apr 2026 00:00:00 +0000</pubDate>
      <guid>https://chanyeols.com/posts/linux-server-performance-monitoring-troubleshooting-with-top-iostat-vmstat/</guid>
      <description>linux-server-performance-monitoring-troubleshooting-with-top-iostat-vmstat</description>
      <content:encoded><![CDATA[<h2 id="linux-성능-튜닝-트러블슈팅-top-iostat-vmstat로-문제-해결">Linux 성능 튜닝 트러블슈팅: top, iostat, vmstat로 문제 해결</h2>
<p>Linux 서버 성능 병목 현상을 해결하는 것은 시스템 관리자와 DevOps 엔지니어의 핵심 역량입니다. <strong>top</strong>, <strong>iostat</strong>, <strong>vmstat</strong>과 같은 기본 제공 도구를 활용하면 CPU, 메모리, 디스크 I/O, 페이징 등 다양한 지표에서 발생하는 문제를 정확히 진단할 수 있습니다. 이 가이드에서는 각 도구의 기본 사용법부터 실제 트러블슈팅 사례까지 단계별로 설명합니다.</p>
<h2 id="1-linux-성능-모니터링-도구-기본-사용법">1. Linux 성능 모니터링 도구 기본 사용법</h2>
<h3 id="11-top-실시간-cpu메모리-모니터링">1.1 top: 실시간 CPU/메모리 모니터링</h3>
<p><code>top</code>은 Linux 시스템의 실시간 상태를 확인하는 가장 기본적인 도구입니다. CPU 사용률, 메모리 사용량, 실행 중인 프로세스 목록 등을 1초 단위로 업데이트하여 보여줍니다.</p>
<div class="highlight"><pre tabindex="0" style="color:#e6edf3;background-color:#0d1117;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;"><code class="language-bash" data-lang="bash"><span style="display:flex;"><span><span style="color:#8b949e;font-style:italic"># 기본 top 실행 (1초 간격)</span>
</span></span><span style="display:flex;"><span>top
</span></span><span style="display:flex;"><span>
</span></span><span style="display:flex;"><span><span style="color:#8b949e;font-style:italic"># 상세 프로세스 정보 확인 (커널 스레드 포함)</span>
</span></span><span style="display:flex;"><span>top -H
</span></span><span style="display:flex;"><span>
</span></span><span style="display:flex;"><span><span style="color:#8b949e;font-style:italic"># CPU 사용률 높은 프로세스 상위 10개 출력</span>
</span></span><span style="display:flex;"><span>ps auxf --sort<span style="color:#ff7b72;font-weight:bold">=</span>-%cpu | head -n <span style="color:#a5d6ff">12</span>
</span></span></code></pre></div><blockquote>
<p><strong>Tip</strong>: <code>top</code> 실행 후 <code>1</code> 키를 눌러 CPU 코어별 사용률을 확인할 수 있습니다. <code>shift + p</code>는 CPU 사용률 기준 정렬, <code>shift + m</code>은 메모리 사용률 기준 정렬입니다.</p>
</blockquote>
<h3 id="12-iostat-디스크-io-병목-진단">1.2 iostat: 디스크 I/O 병목 진단</h3>
<p><code>iostat</code>(I/O statistics)는 디스크 장치의 읽기/쓰기 성능, 대기 시간, 처리량 등을 모니터링합니다. <code>sysstat</code> 패키지에 포함되어 있으며, CentOS/RHEL에서는 <code>yum install sysstat</code>으로 설치 가능합니다.</p>
<div class="highlight"><pre tabindex="0" style="color:#e6edf3;background-color:#0d1117;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;"><code class="language-bash" data-lang="bash"><span style="display:flex;"><span><span style="color:#8b949e;font-style:italic"># 1초 간격으로 5회 디스크 I/O 통계 출력</span>
</span></span><span style="display:flex;"><span>iostat -xz <span style="color:#a5d6ff">1</span> <span style="color:#a5d6ff">5</span>
</span></span><span style="display:flex;"><span>
</span></span><span style="display:flex;"><span><span style="color:#8b949e;font-style:italic"># 특정 디스크 장치(sda) 모니터링</span>
</span></span><span style="display:flex;"><span>iostat -x sda <span style="color:#a5d6ff">1</span> <span style="color:#a5d6ff">10</span>
</span></span></code></pre></div><blockquote>
<p><strong>주의</strong>: <code>iostat</code>의 <code>await</code>(평균 I/O 처리 시간) 값이 10ms 이상이면 디스크 병목 가능성이 높습니다. <code>avgqu-sz</code>(평균 요청 큐 크기)가 1을 초과하면 I/O 대기열이 쌓이기 시작한다는 신호입니다.</p>
</blockquote>
<h3 id="13-vmstat-시스템-전체-상태-종합-분석">1.3 vmstat: 시스템 전체 상태 종합 분석</h3>
<p><code>vmstat</code>(Virtual Memory Statistics)는 CPU, 메모리, 페이징, 블록 I/O, 트랩, 디스크 등 시스템 전반의 상태를 한 번에 확인할 수 있는 강력한 도구입니다.</p>
<div class="highlight"><pre tabindex="0" style="color:#e6edf3;background-color:#0d1117;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;"><code class="language-bash" data-lang="bash"><span style="display:flex;"><span><span style="color:#8b949e;font-style:italic"># 1초 간격으로 10회 시스템 통계 출력</span>
</span></span><span style="display:flex;"><span>vmstat <span style="color:#a5d6ff">1</span> <span style="color:#a5d6ff">10</span>
</span></span><span style="display:flex;"><span>
</span></span><span style="display:flex;"><span><span style="color:#8b949e;font-style:italic"># 5초 간격으로 20회 상세 출력 (disk stats 포함)</span>
</span></span><span style="display:flex;"><span>vmstat -d <span style="color:#a5d6ff">5</span> <span style="color:#a5d6ff">20</span>
</span></span></code></pre></div><blockquote>
<p><strong>중요 지표</strong>:</p>
<ul>
<li><code>us</code>(user), <code>sy</code>(system), <code>id</code>(idle): CPU 사용 시간 비율</li>
<li><code>si</code>(swap in), <code>so</code>(swap out): 스와핑 발생 여부</li>
<li><code>cs</code>(context switch): 컨텍스트 스위칭 빈도 (10,000 이상이면 문제 가능성)</li>
</ul>
</blockquote>
<h2 id="2-cpu-과부하-문제-해결-방법">2. CPU 과부하 문제 해결 방법</h2>
<h3 id="21-top으로-cpu-집약적-프로세스-식별">2.1 top으로 CPU 집약적 프로세스 식별</h3>
<p>CPU 사용률이 80% 이상 지속적으로 높게 나타난다면, <code>top</code>을 통해 문제 프로세스를 식별해야 합니다.</p>
<div class="highlight"><pre tabindex="0" style="color:#e6edf3;background-color:#0d1117;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;"><code class="language-bash" data-lang="bash"><span style="display:flex;"><span><span style="color:#8b949e;font-style:italic"># 명령행 인자까지 표시 (CPU 사용률 높은 프로세스 확인)</span>
</span></span><span style="display:flex;"><span>top -c
</span></span><span style="display:flex;"><span>
</span></span><span style="display:flex;"><span><span style="color:#8b949e;font-style:italic"># CPU 사용률 기준 상위 5개 프로세스</span>
</span></span><span style="display:flex;"><span>ps -eo pid,comm,%cpu --sort<span style="color:#ff7b72;font-weight:bold">=</span>-%cpu | head -n <span style="color:#a5d6ff">6</span>
</span></span></code></pre></div><blockquote>
<p><strong>예시 시나리오</strong>: 특정 Python 프로세스가 95% CPU를 점유하는 경우, 코드 내의 무한 루프 또는 비효율적인 알고리즘이 원인일 수 있습니다.</p>
</blockquote>
<h3 id="22-iostat으로-디스크-관련-cpu-지연-확인">2.2 iostat으로 디스크 관련 CPU 지연 확인</h3>
<p>CPU 사용률은 낮지만 시스템이 느리게 반응할 경우, 디스크 I/O 대기 시간으로 인한 CPU 지연이 발생할 수 있습니다.</p>
<div class="highlight"><pre tabindex="0" style="color:#e6edf3;background-color:#0d1117;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;"><code class="language-bash" data-lang="bash"><span style="display:flex;"><span><span style="color:#8b949e;font-style:italic"># 확장된 디스크 통계 출력 (avgqu-sz, await 확인)</span>
</span></span><span style="display:flex;"><span>iostat -xz <span style="color:#a5d6ff">1</span>
</span></span></code></pre></div><blockquote>
<p><code>await</code> 값이 20ms 이상이면 스토리지 성능 문제를 의심해야 합니다. SSD 기준 일반적으로 0.1ms 미만, HDD는 5~10ms 사이가 정상입니다.</p>
</blockquote>
<h3 id="23-vmstat으로-컨텍스트-스위칭-분석">2.3 vmstat으로 컨텍스트 스위칭 분석</h3>
<p>높은 컨텍스트 스위칭(<code>cs</code>) 비율은 스레드 경합 또는 과도한 멀티태스킹을 나타냅니다.</p>
<div class="highlight"><pre tabindex="0" style="color:#e6edf3;background-color:#0d1117;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;"><code class="language-bash" data-lang="bash"><span style="display:flex;"><span><span style="color:#8b949e;font-style:italic"># 1초 간격으로 컨텍스트 스위칭 모니터링</span>
</span></span><span style="display:flex;"><span>vmstat <span style="color:#a5d6ff">1</span> <span style="color:#a5d6ff">5</span>
</span></span></code></pre></div><blockquote>
<p><code>cs</code> 값이 CPU 코어당 초당 2,000회를 초과하면 성능 저하가 발생할 수 있습니다. 예를 들어 4코어 시스템에서 <code>cs</code> 값이 10,000 이상이면 조사가 필요합니다.</p>
</blockquote>
<h2 id="3-메모리-및-디스크-병목-트러블슈팅">3. 메모리 및 디스크 병목 트러블슈팅</h2>
<h3 id="31-메모리-부족-현상-감지">3.1 메모리 부족 현상 감지</h3>
<p><code>vmstat</code>에서 <code>si</code>/<code>so</code> 값이 0보다 크면 스와핑이 발생하고 있음을 의미합니다.</p>
<div class="highlight"><pre tabindex="0" style="color:#e6edf3;background-color:#0d1117;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;"><code class="language-bash" data-lang="bash"><span style="display:flex;"><span><span style="color:#8b949e;font-style:italic"># 메모리 및 스와핑 모니터링</span>
</span></span><span style="display:flex;"><span>vmstat -s
</span></span><span style="display:flex;"><span>
</span></span><span style="display:flex;"><span><span style="color:#8b949e;font-style:italic"># 실시간 메모리 사용량 확인</span>
</span></span><span style="display:flex;"><span>free -m
</span></span></code></pre></div><blockquote>
<p>스와핑이 지속되면 애플리케이션 성능이 급격히 저하됩니다. <code>swapiness</code> 값을 조정하여 스와핑을 최소화할 수 있습니다.</p>
</blockquote>
<div class="highlight"><pre tabindex="0" style="color:#e6edf3;background-color:#0d1117;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;"><code class="language-bash" data-lang="bash"><span style="display:flex;"><span><span style="color:#8b949e;font-style:italic"># swapiness 값 확인 및 조정</span>
</span></span><span style="display:flex;"><span>cat /proc/sys/vm/swappiness
</span></span><span style="display:flex;"><span>sysctl vm.swappiness<span style="color:#ff7b72;font-weight:bold">=</span><span style="color:#a5d6ff">10</span>
</span></span></code></pre></div><h3 id="32-디스크-io-병목-해결">3.2 디스크 I/O 병목 해결</h3>
<p><code>iostat</code>에서 <code>%util</code>(디스크 사용률)이 100%에 가까우면 디스크 대역폭이 포화 상태임을 의미합니다.</p>
<div class="highlight"><pre tabindex="0" style="color:#e6edf3;background-color:#0d1117;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;"><code class="language-bash" data-lang="bash"><span style="display:flex;"><span><span style="color:#8b949e;font-style:italic"># 디스크 사용률 모니터링</span>
</span></span><span style="display:flex;"><span>iostat -d <span style="color:#a5d6ff">1</span> <span style="color:#a5d6ff">5</span>
</span></span></code></pre></div><blockquote>
<p><strong>해결 방안</strong>:</p>
<ol>
<li>I/O 집약적 작업을 비동기 처리</li>
<li>파일 시스템 캐싱 최적화 (noatime 옵션)</li>
<li>RAID 구성 또는 SSD로 업그레이드</li>
<li><code>ionice</code>로 I/O 우선순위 조정
<div class="highlight"><pre tabindex="0" style="color:#e6edf3;background-color:#0d1117;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;"><code class="language-bash" data-lang="bash"><span style="display:flex;"><span><span style="color:#8b949e;font-style:italic"># 백그라운드 작업에 ionice 적용</span>
</span></span></code></pre></div></li>
</ol>
</blockquote>
<p>tar -cf backup.tar /data/ | ionice -c 3 &gt; backup.tar.bz2</p>
<blockquote>
<pre tabindex="0"><code></code></pre></blockquote>
<h2 id="4-실제-사례-cpu-과부하-문제-해결">4. 실제 사례: CPU 과부하 문제 해결</h2>
<h3 id="41-문제-상황">4.1 문제 상황</h3>
<ul>
<li>CPU 사용률 95% 이상 지속</li>
<li><code>top</code>에서 <code>java</code> 프로세스 1개가 90% CPU 점유</li>
<li><code>iostat</code>에서 <code>await</code> 0.5ms (정상)</li>
<li><code>vmstat</code>에서 <code>cs</code> 1,200/초 (정상 범위)</li>
</ul>
<h3 id="42-해결-과정">4.2 해결 과정</h3>
<ol>
<li><code>top -H -p &lt;PID&gt;</code>로 Java 프로세스 내 스레드 확인</li>
<li><code>jstack &lt;PID&gt;</code>로 스레드 덤프 분석</li>
<li>특정 HTTP 요청 처리 시 무한 루프 발견</li>
<li>코드 수정 후 CPU 사용률 15%로 감소</li>
</ol>
<h2 id="5-공식-문서-및-추가-자료">5. 공식 문서 및 추가 자료</h2>
<ul>
<li><a href="https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/8/html/performance_tuning_guide/">Red Hat Enterprise Linux 8 Performance Tuning Guide</a></li>
<li><a href="https://linux.die.net/man/1/iostat">sysstat documentation (iostat, vmstat 등)</a></li>
</ul>
<h2 id="결론">결론</h2>
<p><code>top</code>, <code>iostat</code>, <code>vmstat</code>은 Linux 성능 문제의 80% 이상을 해결할 수 있는 핵심 도구입니다. 이 세 가지 도구를 조합해 사용하면 CPU, 메모리, 디스크, 네트워크 등 다양한 계층에서 발생하는 병목 현상을 정확히 진단할 수 있습니다. 문제 발생 시 반드시 <strong>지표 간 상관관계</strong>를 분석하는 습관을 기르세요. 예를 들어 CPU 사용률이 높은데 <code>iostat</code>의 <code>await</code>도 높다면, 디스크 I/O로 인한 CPU 대기 상태일 수 있습니다.</p>
<blockquote>
<p><strong>최종 점검 리스트</strong>:</p>
<ol>
<li><code>top</code>으로 CPU/메모리 사용 프로세스 확인</li>
<li><code>iostat</code>으로 디스크 병목 여부 판단</li>
<li><code>vmstat</code>으로 컨텍스트 스위칭/페이징 이상 패턴 감지</li>
<li>모든 지표를 종합적으로 분석</li>
</ol>
</blockquote>
]]></content:encoded>
    </item>
  </channel>
</rss>
