[CKA] kubernetes 리소스 조정(CPU,MEM)
하나의 노드에 여러 컨테이너 파드가 뜰 수 있으며 리소스 제한을 두지 않는다면 하나의 파드가 리소스를 다써버려 다른 파드에 장애가 나게 된다.
우리는 이를 방지 하기 위해 Resource Requests를 사용하여 리소스 제한을 두도록 한다!
그리고 너무 타이트한 파드 배치가 되지 않도록 어느정도 리소스의 여유가 있는 노드에 할당하고 싶다면 Resource Requests 기능을 이용하면 된다!
리소스 조정 항목 | 내용 |
Resource Requests | 파드를 실행하기 위한 최소 리소스양을 요청 |
Resource Limits | 파드가 사용할 수 있는 최대 리소스양을 제한 |
단위는 아래를 참고한다.
MB | 1000KB |
1Mib | 1024Kib |
1core | 1000mc |
이제 nginx 컨테이너 파드를 요청하는데 request를 memory 100Mi cpu 1개로 지정해보자!
# nginx.yaml
apiVersion: v1
kind: Pod
metadata:
labels:
run: my-nginx
name: my-nginx
spec:
containers:
- image: nginx
name: my-nginx
ports:
- containerPort: 80
protocol: TCP
resources:
requests:
memory: 500Mi
cpu: 1
위 nginx.yaml 파일을 가지고 파드를 생성한다.
[node1 ~]$ kubectl create -f nginx.yaml
pod/my-nginx created
파드 정보를 보면 정상적으로 생성 되었으며
[node1 ~]$ kubectl get pods
NAME READY STATUS RESTARTS AGE
my-nginx 1/1 Running 0 20s
상세 정보를 보면 아래와 같이 request 가 원하는대로 설정 된것을 볼 수 있다.
[node1 ~]$ kubectl describe pod my-nginx
Name: my-nginx
Namespace: default
...
IPs:
IP: 10.5.1.2
Containers:
my-nginx:
Container ID: containerd://123d6eb1bdc325b353988798c7295648bb2e8d60d9015d0b194e3ce23887f851
Image: nginx
Image ID: docker.io/library/nginx@sha256:104c7c5c54f2685f0f46f3be607ce60da7085da3eaa5ad22d3d9f01594295e9c
Port: 80/TCP
Host Port: 0/TCP
State: Running
Started: Tue, 29 Aug 2023 11:47:10 +0000
Ready: True
Restart Count: 0
Requests:
cpu: 1
memory: 500Mi
다음 실습을 위해 파드를 제거한다.
[node1 ~]$ kubectl delete pod --all
pod "my-nginx" deleted
[node1 ~]$
이제 limit 리소스 제한 설정을 진행하며 아래와 같이 설정 하면 된다.
# nginx.yaml
apiVersion: v1
kind: Pod
metadata:
creationTimestamp: null
labels:
run: my-nginx
name: my-nginx
spec:
containers:
- image: nginx
name: my-nginx
ports:
- containerPort: 80
protocol: TCP
resources:
limits:
memory: 500Mi
cpu: 1
nginx 파드 정보를 보면 설정한 limit 만큼 request 설정도 같은 값으로 지정 되는것을 볼 수 있다.
[node1 ~]$ kubectl describe pod my-nginx
Name: my-nginx
Namespace: default
...
Limits:
cpu: 1
memory: 500Mi
Requests:
cpu: 1
memory: 500Mi
다음 실습을 위해 모든 파드를 제거한다.
[node1 ~]$ kubectl delete pod --all
pod "my-nginx" deleted
만약에 리소스를 크게 설정하면 어떻게 될까 ?
yaml 파일을 아래와 같이 수정하고 생성해본다.
apiVersion: v1
kind: Pod
metadata:
creationTimestamp: null
labels:
run: my-nginx
name: my-nginx
spec:
containers:
- image: nginx
name: my-nginx
ports:
- containerPort: 80
protocol: TCP
resources:
limits:
memory: 500Mi
cpu: 100
pod 항목을 보면 pending 상태로 원하는 리소스를 가진 노드가 없어 노드 할당 되지 않아 Running 되지 않는다.
[node1 ~]$ kubectl get pods
NAME READY STATUS RESTARTS AGE
my-nginx 0/1 Pending 0 10s
이처럼 리소스 요청, 제한을 너무 크게 잡으면 파드가 생성되지 않을 수 있다는 것을 알 수 있다.
이제 request, limit 두가지를 모두 설정 하는 실습을 진행하며 아래와 같이 하면 된다.
apiVersion: v1
kind: Pod
metadata:
creationTimestamp: null
labels:
run: my-nginx
name: my-nginx
spec:
containers:
- image: nginx
name: my-nginx
ports:
- containerPort: 80
protocol: TCP
resources:
limits:
memory: 200Mi
cpu: 2
requests:
memory: 100Mi
cpu: 1
아래와 같이 정상적으로 조회 되는것을 볼 수 있다.
[node1 ~]$ kubectl describe pod my-nginx
Name: my-nginx
Namespace: default
...
Limits:
cpu: 2
memory: 200Mi
Requests:
cpu: 1
memory: 100Mi
끝!