java application의 경우 kubernetes의 리소스 제한만 하면 메모리가 꽉차서 Out-Of-Memory(OOM) 가 발생하고 pod가 리스타트 되는 경우가 있습니다.
아래와 같은 방법으로 해당 application의 스펙에서 java 의 heap 메모리를 제한해서 kubernetes가 pod를 kill 시키지 않도록 설정해야 합니다.
예를 들면 Elasticsearch의 경우 ES_JAVA_OPTS 환경 변수를 사용해서 아래와 같이 힙(Heap) 메모리를 제한할 수 있습니다.
apiVersion: apps/v1
kind: Deployment
metadata:
name: elasticsearch-logging-data
spec:
replicas: 1
selector:
matchLabels:
app: elasticsearch
template:
metadata:
labels:
app: elasticsearch
spec:
containers:
- name: elasticsearch
image: docker.elastic.co/elasticsearch/elasticsearch:7.11.0
env:
- name: ES_JAVA_OPTS
value: "-Xms2g -Xmx2g"
resources:
requests:
memory: "2Gi"
cpu: "500m"
limits:
memory: "4Gi"
cpu: "2"
728x90
댓글