Go pprof와 Docker 통계 간에 "사용된 메모리" 측정항목이 다른 이유
컨텍스트
다음에서 실행되는 Go 애플리케이션 Docker 컨테이너에서 docker stats 명령은 선형적으로 증가하는 메모리 사용량을 보고합니다. 그러나 HTTP pprof를 사용하여 실행 중인 애플리케이션을 모니터링하면 Runtime.MemStats.sys 값이 일정하게 유지됩니다. 이러한 불일치는 잠재적인 메모리 누수에 대한 의문을 제기합니다.
Cgroups 및 메모리 지표
Docker 통계는 cgroups에서 메모리 사용량 통계를 검색하여 캐시라인 거짓 공유를 방지하기 위해 메모리 액세스를 최적화합니다. 결과적으로 cgroups의 Usage_in_bytes 지표에는 컨테이너 내의 파일 I/O를 설명하는 페이지 캐시와 RES가 모두 포함됩니다.
메모리 회수
컨테이너의 메모리가 사용량이 최대 한도에 도달하면 프로세스를 종료하는 대신 사용되지 않은 메모리를 회수합니다. 이는 pprof가 일정한 런타임.MemStats.sys 값을 보고하는 반면 docker stats는 선형적으로 증가하는 메모리 사용량을 표시하는 이유를 설명합니다.
확인
이 동작을 확인하려면 다음을 추가하세요. docker run 명령이나 docker-compose.yml 파일을 사용하여 컨테이너에 대한 메모리 제한을 설정합니다. 제한에 도달하면 /sys/fs/cgroup/memory/docker//의 cgroups에 표시된 대로 컨테이너가 메모리를 회수하고 해당 사용량을 제한 이하로 유지합니다.
결론
pprof와 docker stats에서 보고한 메모리 사용량의 차이는 docker 통계 및 메모리 제한이 적용될 때 cgroup이 수행하는 메모리 회수 작업. 이러한 요소를 이해함으로써 개발자는 컨테이너의 메모리 소비를 보다 정확하게 파악할 수 있습니다.
위 내용은 Go pprof와 Docker 통계가 다른 메모리 사용량 측정항목을 표시하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!