본문 바로가기
CSP (Cloud Service Provider)/GCP

GKE deamonset

by BTC_안민규 2022. 8. 5.

데몬셋에는 두가지 업데이트 방법이 있다.

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

네임 스페이스에서 데몬셋을 삭제

댓글