이 페이지에서는 Bazel이 사용하는 메모리를 제한하고 줄이는 방법을 설명합니다.
제한된 RAM으로 Bazel 실행
경우에 따라 Bazel이 최소한의 메모리를 사용하도록 할 수 있습니다. --host_jvm_args=-Xmx2g
와 같이 시작 플래그 --host_jvm_args
를 통해 최대 힙을 설정할 수 있습니다.
하지만 빌드가 충분히 크면 메모리가 충분하지 않을 때 Bazel에서 OutOfMemoryError
(OOM)을 발생시킬 수 있습니다. 다음 명령어 플래그(--discard_analysis_cache
, --nokeep_state_after_build
, --notrack_incremental_state
)를 전달하여 Bazel이 더 적은 메모리를 사용하도록 할 수 있습니다. 단, 이 경우 증분 빌드 속도가 느려집니다.
이러한 플래그를 사용하면 Bazel이 빌드에 사용하는 메모리가 최소화되지만 향후 빌드 속도가 표준 증분 빌드보다 느려집니다.
다음 플래그 중 하나를 개별적으로 전달할 수도 있습니다.
--discard_analysis_cache
는 분석이 아닌 실행 중에 사용되는 메모리를 줄입니다. 증분 빌드는 패키지 로드를 다시 실행할 필요가 없지만 분석과 실행은 다시 실행해야 합니다 (디스크에 있는 작업 캐시로 대부분의 재실행을 방지할 수 있음).--notrack_incremental_state
는 Bazel의 내부 종속 항목 그래프에 에지를 저장하지 않으므로 증분 빌드에는 사용할 수 없습니다. 다음 빌드에서 이 데이터는 삭제되지만--nokeep_state_after_build
가 지정되지 않는 한 내부 디버깅을 위해 그때까지 보존됩니다.--nokeep_state_after_build
는 빌드 후 모든 데이터를 삭제하므로 증분 빌드는 디스크에 있는 작업 캐시를 제외하고 처음부터 빌드해야 합니다. 단독으로 현재 빌드의 최고점에 영향을 미치지는 않습니다.
메모리 프로파일링
Bazel에는 규칙의 메모리 사용량을 확인하는 데 도움이 되는 메모리 프로파일러가 내장되어 있습니다. 맞춤 규칙의 성능을 개선하는 방법에 관한 문서의 메모리 프로파일링 섹션에서 이 프로세스에 대해 자세히 알아보세요.