쿠버네티스 StatefulSet

1 개요[ | ]

쿠버네티스 StatefulSet (sts)
Kubernetes 스테이트풀셋
  • Pod의 스케일링을 관리하고, Pod들에 대한 배치와 유일성을 보장한다.
  • Deployment와 유사하지만 다르다.
  • Unique한 Pod으로 관리하며, 순서를 보장한다.
  • Deployment와 마찬가지로 동일 컨테이너 스펙을 기반으로 Pod들을 관리하지만, Deployment와는 달리 Pod 각각에 대해 스티키 identity를 유지한다.
  • Pod들은 같은 스펙으로 생성되지만 교체는 불가능하다.
각각은 persistent 식별자를 가지며, 리스케줄링시에도 계속 유지된다.
  • 기타 다른 컨트롤러와 같은 패턴으로 운영된다.
StatefulSet 객체에 원하는 상태를 정의하면, StatefulSet 컨트롤러는 현재 상태에서 그 원하는 상태로 이행하기 위해 필요한 업데이트를 생성한다.
  • k8s 1.9에서 stable
apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: web
spec:
  selector:
    matchLabels:
      app: nginx # has to match .spec.template.metadata.labels
  serviceName: "nginx"
  replicas: 3 # by default is 1
  template:
    metadata:
      labels:
        app: nginx # has to match .spec.selector.matchLabels
    spec:
      terminationGracePeriodSeconds: 10
      containers:
      - name: nginx
        image: k8s.gcr.io/nginx-slim:0.8
        ports:
        - containerPort: 80
          name: web
        volumeMounts:
        - name: www
          mountPath: /usr/share/nginx/html
  volumeClaimTemplates:
  - metadata:
      name: www
    spec:
      accessModes: [ "ReadWriteOnce" ]
      resources:
        requests:
          storage: 1Gi

2 같이 보기[ | ]

3 참고[ | ]

문서 댓글 ({{ doc_comments.length }})
{{ comment.name }} {{ comment.created | snstime }}