Vmstat 및 Iostat 명령어를 사용한 Linux 성능 모니터링

이것은 Linux 명령어Linux 성능 모니터링의 지속적인 시리즈입니다. 이 기사에서는 VmstatIostat 명령어에 대해 배우게 될 것입니다. 이 명령어들은 모든 주요 유닉스 계열 (Linux/Unix/FreeBSD/Solaris) 운영 체제에서 사용할 수 있습니다.

vmstat 명령어(가상 메모리 통계 도구라고도 함)는 Linux에서 프로세스, 메모리, 디스크 및 CPU 활동에 대한 정보를 보여줍니다. 반면 iostat 명령어는 CPU 사용률, 모든 디스크 및 파티션에 대한 시스템 입력/출력 통계를 모니터링하는 데 사용됩니다.

만약 vmstatiostat 명령어가 없는 Linux 머신이라면 sysstat 패키지를 설치하십시오. vmstat, sar, iostat 명령어는 sysstat – 시스템 모니터링 도구에 포함된 패키지 모음입니다.

다운로드하고 sysstat를 링크 sysstat에서 소스 tarball을 사용하여 설치할 수 있지만 패키지 관리자를 통한 설치를 권장합니다.

리눅스에서 Sysstat 설치하기

$ sudo apt install sysstat         [On Debian, Ubuntu and Mint]
$ sudo yum install sysstat         [On RHEL/CentOS/Fedora and Rocky Linux/AlmaLinux]
$ sudo emerge -a app-admin/sysstat [On Gentoo Linux]
$ sudo pacman -S sysstat           [On Arch Linux]
$ sudo zypper install sysstat      [On OpenSUSE]    
Install Sysstat in Linux

리눅스에서 Vmstat 명령어 예제 배우기

이 섹션에서는 6가지 vmstat 명령어 예제와 스크린샷으로 사용법을 배웁니다.

1. 활성 및 비활성 메모리 나열하기

다음 예에서는 여섯 개의 열이 있습니다. 열의 의미는 vmstat의 매뉴얼 페이지에 자세히 설명되어 있습니다. 가장 중요한 필드는 메모리 아래의 free와 스왑 열 아래의 si, so입니다.

[root@tecmint ~]# vmstat -a

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
 r  b   swpd   free  inact active   si   so    bi    bo   in   cs us sy id wa st
 1  0      0 810420  97380  70628    0    0   115     4   89   79  1  6 90  3  0
  • Free – 사용 가능한/유휴 메모리 공간의 양.
  • si – 디스크에서 매초 스왑되어 들어오는 킬로바이트 단위.
  • so – 디스크로 매초 스왑되어 나가는 킬로바이트 단위.

참고: vmstat 매개변수 없이 실행하면 시스템 부팅 이후의 요약 보고서가 표시됩니다.

2. vmstat ‘X’초 실행 및 (‘실행 횟수’)

이 명령어로 vmstat는 2초마다 실행되며 6개의 간격 실행 후 자동으로 중지됩니다.

[root@tecmint ~]# vmstat 2 6

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 0  0      0 810420  22064 101368    0    0    56     3   50   57  0  3 95  2  0
 0  0      0 810412  22064 101368    0    0     0     0   16   35  0  0 100  0  0
 0  0      0 810412  22064 101368    0    0     0     0   14   35  0  0 100  0  0
 0  0      0 810412  22064 101368    0    0     0     0   17   38  0  0 100  0  0
 0  0      0 810412  22064 101368    0    0     0     0   17   35  0  0 100  0  0
 0  0      0 810412  22064 101368    0    0     0     0   18   36  0  1 100  0  0

3. 타임스탬프가 있는 Vmstat

vmstat 명령어에 -t 매개변수를 사용하면 아래와 같이 각 줄에 타임스탬프가 표시됩니다.

[tecmint@tecmint ~]$ vmstat -t 1 5

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu------ ---timestamp---
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 0  0      0 632028  24992 192244    0    0    70     5   55   78  1  3 95  1  0        2012-09-02 14:57:18 IST
 1  0      0 632028  24992 192244    0    0     0     0  171  514  1  5 94  0  0        2012-09-02 14:57:19 IST
 1  0      0 631904  24992 192244    0    0     0     0  195  600  0  5 95  0  0        2012-09-02 14:57:20 IST
 0  0      0 631780  24992 192244    0    0     0     0  156  524  0  5 95  0  0        2012-09-02 14:57:21 IST
 1  0      0 631656  24992 192244    0    0     0     0  189  592  0  5 95  0  0        2012-09-02 14:57:22 IST

4. 다양한 카운터의 통계

vmstat 명령어에 -s 스위치를 사용하면 다양한 이벤트 카운터와 메모리 통계의 요약을 표시합니다.

[tecmint@tecmint ~]$ vmstat -s

      1030800  total memory
       524656  used memory
       277784  active memory
       185920  inactive memory
       506144  free memory
        26864  buffer memory
       310104  swap cache
      2064376  total swap
            0  used swap
      2064376  free swap
         4539 non-nice user cpu ticks
            0 nice user cpu ticks
        11569 system cpu ticks
       329608 idle cpu ticks
         5012 IO-wait cpu ticks
           79 IRQ cpu ticks
           74 softirq cpu ticks
            0 stolen cpu ticks
       336038 pages paged in
        67945 pages paged out
            0 pages swapped in
            0 pages swapped out
       258526 interrupts
       392439 CPU context switches
   1346574857 boot time
         2309 forks

5. Linux 디스크 통계監視

vmstat-d 옵션과 함께 사용하면 Linux의 모든 디스크 통계를 표시합니다.

[tecmint@tecmint ~]$ vmstat -d

disk- ------------reads------------ ------------writes----------- -----IO------
       total merged sectors      ms  total merged sectors      ms    cur    sec
ram0       0      0       0       0      0      0       0       0      0      0
ram1       0      0       0       0      0      0       0       0      0      0
ram2       0      0       0       0      0      0       0       0      0      0
ram3       0      0       0       0      0      0       0       0      0      0
ram4       0      0       0       0      0      0       0       0      0      0
ram5       0      0       0       0      0      0       0       0      0      0
ram6       0      0       0       0      0      0       0       0      0      0
ram7       0      0       0       0      0      0       0       0      0      0
ram8       0      0       0       0      0      0       0       0      0      0
ram9       0      0       0       0      0      0       0       0      0      0
ram10      0      0       0       0      0      0       0       0      0      0
ram11      0      0       0       0      0      0       0       0      0      0
ram12      0      0       0       0      0      0       0       0      0      0
ram13      0      0       0       0      0      0       0       0      0      0
ram14      0      0       0       0      0      0       0       0      0      0
ram15      0      0       0       0      0      0       0       0      0      0
loop0      0      0       0       0      0      0       0       0      0      0
loop1      0      0       0       0      0      0       0       0      0      0
loop2      0      0       0       0      0      0       0       0      0      0
loop3      0      0       0       0      0      0       0       0      0      0
loop4      0      0       0       0      0      0       0       0      0      0
loop5      0      0       0       0      0      0       0       0      0      0
loop6      0      0       0       0      0      0       0       0      0      0
loop7      0      0       0       0      0      0       0       0      0      0
sr0        0      0       0       0      0      0       0       0      0      0
sda     7712   5145  668732  409619   3282  28884  257402  644566      0    126
dm-0   11578      0  659242 1113017  32163      0  257384 8460026      0    126
dm-1     324      0    2592    3845      0      0       0       0      0      2

6. 메가바이트 단위로 통계 표시

vmstat 명령어는 기본적으로 메모리 통계를 킬로바이트 단위로 표시하지만, -S M 인자를 사용하면 메모리 크기를 메가바이트 단위로 보고서를 출력할 수 있습니다. 다음 예제를 참고하세요.

[root@tecmint ~]# vmstat -S M 1 5

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 0  0      0    346     53    476    0    0    95     8   42   55  0  2 96  2  0
 0  0      0    346     53    476    0    0     0     0   12   15  0  0 100  0  0
 0  0      0    346     53    476    0    0     0     0   32   62  0  0 100  0  0
 0  0      0    346     53    476    0    0     0     0   15   13  0  0 100  0  0
 0  0      0    346     53    476    0    0     0     0   34   61  0  1 99  0  0

Linux에서 iostat 명령어 예제 학습

이 섹션에서는 6가지 iostat 명령어 예제와 스크린샷과 함께 사용법을 배우게 됩니다.

7. 디스크의 CPU와 I/O 통계 표시

iostat 명령어를 인자 없이 실행하면 모든 파티션의 CPUI/O 통계를 아래처럼 표시합니다.

[root@tecmint ~]# iostat

Linux 2.6.32-279.el6.i686 (tecmint.com)         09/03/2012      _i686_  (1 CPU)

avg-cpu:  %user   %nice %system %iowait  %steal   %idle
           0.12    0.01    1.54    2.08    0.00   96.24

Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
sda               3.59       161.02        13.48    1086002      90882
dm-0              5.76       159.71        13.47    1077154      90864
dm-1              0.05         0.38         0.00       2576          0

8. Linux CPU 통계 표시

iostat 명령어에 -c 인자를 사용하면 오직 CPU 통계만 아래처럼 표시합니다.

[root@tecmint ~]# iostat -c

Linux 2.6.32-279.el6.i686 (tecmint.com)         09/03/2012      _i686_  (1 CPU)

avg-cpu:  %user   %nice %system %iowait  %steal   %idle
           0.12    0.01    1.47    1.98    0.00   96.42

9. Linux 디스크 I/O 통계 표시

iostat 명령어에 -d 인자를 사용하면 모든 파티션의 디스크 I/O 통계만 아래처럼 표시합니다.

[root@tecmint ~]# iostat -d

Linux 2.6.32-279.el6.i686 (tecmint.com)         09/03/2012      _i686_  (1 CPU)

Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
sda               3.35       149.81        12.66    1086002      91746
dm-0              5.37       148.59        12.65    1077154      91728
dm-1              0.04         0.36         0.00       2576          0

10. 특정 장치의 I/O 통계 표시

기본적으로 모든 파티션의 통계를 표시하지만, -p 옵션과 장치 이름 인자를 사용하면 특정 장치의 디스크 I/O 통계만 아래처럼 표시합니다.

[root@tecmint ~]# iostat -p sda

Linux 2.6.32-279.el6.i686 (tecmint.com)         09/03/2012      _i686_  (1 CPU)

avg-cpu:  %user   %nice %system %iowait  %steal   %idle
           0.11    0.01    1.44    1.92    0.00   96.52

Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
sda               3.32       148.52        12.55    1086002      91770
sda1              0.07         0.56         0.00       4120         18
sda2              3.22       147.79        12.55    1080650      91752

11. LVM 통계 표시

-N (대문자) 파라미터를 사용하면 LVM 통계만如下처럼 표시됩니다.

[root@tecmint ~]# iostat -N

Linux 2.6.32-279.el6.i686 (tecmint.com)         09/03/2012      _i686_  (1 CPU)

avg-cpu:  %user   %nice %system %iowait  %steal   %idle
           0.11    0.01    1.39    1.85    0.00   96.64

Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
sda               3.20       142.84        12.16    1086002      92466
vg_tecmint-lv_root     5.13       141.68        12.16    1077154      92448
vg_tecmint-lv_swap     0.04         0.34         0.00       2576          0

12. Iostat 버전 확인

-V (대문자) 파라미터를 사용하면 iostat의 버전이如下처럼 표시됩니다.

[root@tecmint ~]# iostat -V

sysstat version 11.7.3
(C) Sebastien Godard (sysstat  orange.fr)

vmstatiostat에는 자세히 설명할 수 없을 수도 있는 여러 열과 플래그가 포함되어 있습니다. 더 알고 싶다면 vmstatiostat의 man 페이지를 참조하세요.

# man vmstat
# man iostat

이篇文章이 유용하다고 생각되면下面的 댓글 상자를 통해 공유해 주세요.

Source:
https://www.tecmint.com/linux-performance-monitoring-with-vmstat-and-iostat-commands/