Linux Vmstat 명령

王林
王林앞으로
2024-03-20 13:49:111295검색

Linux Vmstat命令

이 가이드에서는 Linux에서 "vmstat" 명령을 사용하는 다양한 방법을 보여줍니다.

전제 조건:

이 가이드에 설명된 단계를 수행하려면 다음 구성 요소가 필요합니다.

  • Linux 시스템이 올바르게 구성되었습니다. 테스트 목적으로 Linux VM 사용을 고려해보세요.
  • Sudo 권한이 있는 루트가 아닌 사용자에게 액세스
  • 명령줄 인터페이스에 대한 기본 이해

Linux의 가상 메모리

RAM(물리적 메모리)은 운영 체제에서 실행 중인 프로그램에 할당하는 제한된 리소스입니다. 운영 체제 자체를 포함한 모든 프로그램은 이 공간을 차지해야 합니다.

메모리 수요가 사용 가능한 메모리를 초과하면 시스템이 충돌하거나 프로그램이 더 많은 메모리 공간을 요구할 수 있습니다. 대부분의 경우 이러한 상황은 바람직하지 않습니다. 따라서 시스템이 데이터의 일부를 하드 디스크에 저장하여 필요할 때 RAM으로 교체할 수 있도록 하는 가상 메모리의 개념이 탄생했습니다. 이러한 방식으로 시스템은 메모리 자원을 보다 효율적으로 관리할 수 있어 메모리 부족으로 인한 충돌 없이 프로그램이 정상적으로 실행되도록 할 수 있습니다. 가상 메모리를 사용하면 시스템에 메모리 요구 사항이 발생합니다

가상 메모리는 하드 드라이브나 솔리드 스테이트 드라이브의 공간을 사용하여 필요할 때 추가 메모리 역할을 할 수 있도록 메모리 용량을 확장하는 컴퓨터 시스템의 기술입니다. 가상 메모리는 실제로 프로세서에 더 많은 메모리가 필요할 때 보충할 수 있도록 하드 드라이브 공간의 일부를 임시 저장소로 사용하는 방법입니다. UNIX 및 Linux 운영 체제에서는 이 기술을 스왑 공간이라고 하며 메모리 리소스 할당 및 교환을 관리하는 데 사용됩니다. 가상 메모리는 실제 물리적 메모리는 아니지만 시스템의 성능과 안정성을 향상시키고 시스템이 더 큰 작업 부하를 처리할 수 있도록 보장할 수 있습니다.

Linux 커널은 메모리 블록을 스왑 공간으로 이동하고 필요할 때 다시 RAM으로 검색합니다.

가상 메모리는 일반적으로 물리적 메모리보다 속도가 느리며 저장 장치의 성능에 따라 달라집니다. 그러나 특정 하드웨어 설정(예: NVMe SSD 사용)에서는 가상 메모리의 성능이 RAM과 비슷할 수 있습니다.

vmstat 명령

"vmstat" 명령은 가상 메모리 관련 정보를 모니터링하는 유틸리티 도구입니다. 이는 "sysstat" 패키지의 일부로 모든 Linux 시스템에서 사용할 수 있습니다.

"vmstat"의 명령 구조는 다음과 같습니다:

$vmstat

기본 사용법

매개변수 없이 실행하면 "vmstat"는 마지막 부팅 이후의 시스템 정보를 인쇄합니다.

$vmstat

출력은 6개 부분으로 나뉩니다:

  • procs: 현재 실행 중인 프로세스에 대한 통계
    • r: 활성 프로세스 수
    • b: 수면 프로세스 수
  • 메모리: 메모리 사용 통계
    • Swpd: 총 가상 메모리(스왑 공간)
    • 무료: 사용 가능한 스왑 공간
    • buff: 임시 버퍼 메모리로 사용되는 스왑 공간의 양
    • 캐시: 총 캐시 메모리
  • swap: 스왑 공간에 대한 통계
    • si: 환율
    • 그래서: 스왑 아웃 비율
  • io: I/O 통계
    • bi: 블록 장치에서 수신한 블록 수
    • bo: 블록 장치로 전송된 블록 수
  • 시스템: 일정 통계
    • in: 시스템 인터럽트 횟수
    • cs: 컨텍스트 전환 속도
  • CPU: 다양한 CPU 통계
    • 미국: 커널이 아닌 프로세스에 소비된 CPU 시간
    • sy: CPU가 커널 프로세스에 소비하는 시간
    • id: CPU가 유휴 시간을 보냅니다
    • wa: CPU는 I/O 작업이 완료되기를 기다리는 데 시간을 보냅니다
    • st: 가상 머신이 사용하는 CPU 시간

디스플레이 단위 변경

기본적으로 "vmstat"는 메모리 값을 바이트 단위로 보고합니다. 단위를 변경하려면 "-S" 플래그를 사용하세요.

$vmstat-S

여기서 "vmstat"는 값을 MB 단위로 인쇄합니다.

사용 가능한 여러 메모리 장치가 있습니다:

  • M: 1048576바이트(2^20바이트)
  • M: 1000000바이트(1000킬로바이트)
  • K: 1024바이트(1메가바이트)
  • k: 1000바이트(1바이트)

지속적인 통계 업데이트

기본적으로 "vmstat"는 보고서를 한 번 인쇄합니다. 그러나 "vmstat"에 지정된 간격(초 단위)으로 지속적인 보고서를 제공하도록 지시할 수 있습니다.

명령 구조는 다음과 같습니다:

$vmstat

예를 들어, 2초마다 업데이트된 통계를 얻으려면 명령은 다음과 같습니다.

$vmstat 2

"Ctrl + C"를 사용하여 수동으로 종료하지 않으면 출력이 중지되지 않습니다.

또는 "vmstat"를 지정하여 특정 횟수에 대한 통계를 제공할 수 있습니다.

$vmstat

예를 들어, 2초마다 업데이트되는 통계를 얻으려면 명령은 다음과 같습니다.

$vmstat 2 5

활성 및 비활성 메모리

활성 메모리는 현재 프로세스에서 사용하고 있는 메모리 공간을 말합니다. 반면, 비활성 메모리는 더 이상 실행되지 않는 프로세스에 할당된 메모리 공간을 나타냅니다.

"vmstat"를 사용하면 사용 중인 활성 및 비활성 메모리의 양을 확인할 수 있습니다.

$vmstat—a

여기서 "버프" 및 "캐시" 열은 각각 "비활성" 및 "활성" 열로 대체됩니다.

메모리 및 일정

메모리 및 스케줄링에 대한 더 자세한 보고서를 얻으려면 다음 명령을 사용하십시오:

$vmstat—s

여기:

  • 섹션 1: 이 섹션에서는 총 물리적 메모리, 활성/비활성 메모리, 여유/버퍼/캐시 메모리 등 기본 시스템 정보를 소개합니다.
  • 섹션 2: 다양한 CPU 통계
    • 양호하지 않은 CPU 비트: 우선순위가 높은 프로세스가 CPU를 사용하는 횟수입니다.
    • NICE CPU TICK: 우선 순위가 낮은 프로세스가 CPU를 사용하는 횟수입니다.
    • 시스템 CPU 수: 커널 프로세스가 CPU를 사용한 횟수입니다.
    • 유휴 CPU 틱: CPU가 유휴 상태인 횟수입니다.
    • IO—CPU 틱 대기: CPU가 I/O 관리를 기다리는 횟수입니다.
    • IRQ: CPU가 인터럽트 요청을 받은 횟수입니다.
    • softirq: CPU가 소프트웨어 인터럽트 요청을 받은 횟수입니다.
    • Stolen CPU Time: VM이 CPU 시간을 훔친 횟수입니다.
  • 섹션 3: 메모리 페이징 상태
  • 섹션 4: 이벤트 카운터

부팅 후 포크

포크는 기존 프로세스에서 생성된 프로세스를 나타냅니다. 포크 수에 대한 통계를 얻으려면 다음 명령을 실행하십시오.

$vmstat-f

디스크 및 파티션 통계

"vmstat" 명령은 디스크 활동에 대한 정보도 제공할 수 있습니다. 디스크 활동에 대한 빠른 요약을 얻으려면 다음 명령을 실행하십시오:

$vmstat—D

디스크 활동에 대한 보다 자세한 보고서(읽기/쓰기 통계 포함)를 얻으려면 대신 다음 명령을 사용하십시오.

$vmstat—d

여기:

  • 읽은 내용
    • total: 총 디스크 읽기
    • 병합: 총 그룹 읽기
    • 섹터: 읽은 총 섹터 수
    • ms: 디스크에서 데이터를 읽는 데 걸린 총 시간(밀리초)
  • 님이 쓴 글
    • 총계: 디스크 쓰기 횟수
    • 병합: 총 그룹 쓰기 수
    • 섹터: 작성된 총 섹터 수
    • ms: 디스크에 쓰는 총 시간(밀리초)
  • 이오
    • cur: 현재 총 디스크 읽기/쓰기 수
    • 초: 진행 중인 읽기/쓰기 작업에 소요된 시간(초)

"vmstat" 명령은 특정 디스크 파티션에 대한 보고서를 생성할 수도 있습니다. 파티션 보고서를 얻으려면 다음 명령 구조를 사용하십시오:

$vmstat-p

판 통계

보드 할당은 효율적인 개체 메모리 할당 메커니즘입니다. 슬랩 할당은 이전 메커니즘에 비해 메모리 조각화(메모리 할당 및 할당 취소로 인해 발생)를 줄입니다.

시스템의 슬래브 통계를 확인하려면 다음 “vmstat” 명령을 사용하세요:

$sudo vmstat—m

통계를 보려면 루트 액세스가 필요하다는 점에 유의하세요.

여기:

  • 캐시: 캐시된 데이터의 이름
  • Num: Num 캐시의 활성 개체 수
  • 전체: 특정 캐시에 있는 총 개체 수
  • 크기: 캐시 개체의 크기
  • 페이지: 캐시된 개체의 메모리 페이지 수를 포함합니다

결론

이 가이드에서는 "vmstat" 명령을 사용하는 다양한 방법을 보여주었습니다. 가상 메모리 외에도 "vmstat"는 디스크 통계, 포크, 샤드 등을 보고할 수도 있습니다.

다른 시스템 모니터링 도구에 대해 알고 싶으십니까? HTOP, KILL, PS 등에 대해 자세히 알아보세요.

행복한 컴퓨팅!

위 내용은 Linux Vmstat 명령의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 mryunwei.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제