데몬셋에는 두가지 업데이트 방법이 있다.
OnDelete 데몬셋 템플릿을 업데이트 한 후 이전 데몬셋 파드를 수동으로 삭제할 때
RollingUpdate 기본 업데이트 방법이다. 데몬셋 템플릿을 업데이트 한 후 오래된 데몬셋 파드가 종료되고
새로운 데몬셋 파드는 제어방식으로 자동 생성된다. 전체 업데이트 프로세스 동안 데몬셋의 최대 하나의 파드가 각 노드에서 실행된다.
롤링 업데이트를 사용하기 위해 .spec.updateStrategy.type에 RollingUPdate를 설정해야한다.
yaml 파일에 데몬셋을 명시하고 rollingupdate도 명시한다.
apiVersion: apps/v1
kind: DaemonSet
metadata:
name: fluentd-elasticsearch
namespace: kube-system
labels:
k8s-app: fluentd-logging
spec:
selector:
matchLabels:
name: fluentd-elasticsearch
updateStrategy:
type: RollingUpdate
rollingUpdate:
maxUnavailable: 1
template:
metadata:
labels:
name: fluentd-elasticsearch
spec:
tolerations:
# 이 톨러레이션(toleration)은 마스터 노드에서 실행 가능한 데몬셋이
# 마스터에서 파드를 실행할 수 없는 경우 이를 제거하는 것이다
- key: node-role.kubernetes.io/master
effect: NoSchedule
containers:
- name: fluentd-elasticsearch
image: quay.io/fluentd_elasticsearch/fluentd:v2.5.2
volumeMounts:
- name: varlog
mountPath: /var/log
- name: varlibdockercontainers
mountPath: /var/lib/docker/containers
readOnly: true
terminationGracePeriodSeconds: 30
volumes:
- name: varlog
hostPath:
path: /var/log
- name: varlibdockercontainers
hostPath:
path: /var/lib/docker/containers
데몬셋 매니페스트의 업데이트 전략을 확인한 후 데몬셋을 생성한다.
kubectl apply -f deamonset.yaml
데몬셋 업데이트 확인하고, rollingupdate로 설정되어 있는지 확인한다.
kubectl get ds/fluentd-elasticsearch -o go-template='{{.spec.updateStrategy.type}}{{"\n"}}' -n kube-system
kubectl apply -f https://k8s.io/examples/controllers/fluentd-daemonset.yaml --dry-run=client -o go-template='{{.spec.updateStrategy.type}}{{"\n"}}'
두가지 명령 전부 RollingUpdate가 나와야 한다.
kubectl delete ds fluentd-elasticsearch -n kube-system
네임 스페이스에서 데몬셋을 삭제
'CSP (Cloud Service Provider) > GCP' 카테고리의 다른 글
Secret Manager 만들기 (0) | 2022.08.12 |
---|---|
[GKE] helm으로 모니터링 구성 - helm 설치 (0) | 2022.08.11 |
[Google Cloud Platform] 빅데이터와 머신러닝(4) (0) | 2022.08.05 |
GCP - Google Cloud DNS에 한글 도메인 등록 & 사용하기 (0) | 2022.08.03 |
AWS to GCP Migration (0) | 2022.08.03 |
댓글