정현수
현수 세상
정현수
전체 방문자
오늘
어제
반응형
  • 분류 전체보기 (267)
    • NEXTSTEP 자바스크립트 클린코드 2기 (1)
    • 우테코 4기 (6)
    • 회고록 (5)
    • 개발지식 (6)
    • React (3)
      • React Clone Coding (3)
    • React Native (2)
    • Kubernetes & Docker (36)
      • 궁금한 것 (13)
    • Flutter (2)
    • 알고리즘 (168)
      • 프로그래머스 1단계 (27)
      • 프로그래머스 2단계 (37)
      • 백준 (98)
      • 이론 (6)
    • 자료구조 (3)
    • 유튜브 (1)
    • 책 읽자 (1)
    • 취업준비 (1)
    • 대내 활동 (31)
      • 2022년 겨울방학 알고리즘 특강 (0)
      • 2020년 여름방학 모각코 (13)
      • 2020년 겨울방학 모각코 (13)
      • 웹프로그래밍 상상튜터링 (5)

인기 글

최근 글

공지사항

  • 블로그 이동

태그

  • NodePort
  • 공식문서
  • programmers
  • Deployment
  • image run
  • javascript
  • 개발지식
  • 자바스크립트
  • replicaset
  • React
  • 모각코
  • flutter
  • 그리디
  • 우테코
  • mysql
  • 알고리즘
  • 디플로이먼트
  • docker
  • 노드
  • 프로그래머스
  • kubelet
  • 이코테
  • 파이썬
  • Jenkins
  • image pull
  • 백준
  • 레플리카셋
  • 쿠버네티스
  • 리액트
  • Kubernetes

최근 댓글

블로그 메뉴

  • 홈

티스토리

hELLO · Designed By 정상우.
정현수

현수 세상

쿠버네티스 YAML파일 Selector는 무엇을 가리킬까?
Kubernetes & Docker/궁금한 것

쿠버네티스 YAML파일 Selector는 무엇을 가리킬까?

2020. 7. 16. 16:28
반응형

※주의

이 글은 제가 혼자 공부하면서 여기저기 찾아보고 정리하는 곳이라서

글의 퀄리티나 내용상 맞지 않는 부분들이 있습니다.

공식문서가 더욱 더 큰 도움이 될 수 있습니다!

 

이 글에서 가져온 코드들은 쿠버네티스 공식문서에서 가져왔습니다.

https://kubernetes.io/ko/

 

운영 수준의 컨테이너 오케스트레이션

운영 수준의 컨테이너 오케스트레이션

kubernetes.io

궁금점

디플로이먼트, 서비스, 파드, 레플리카셋등 오브젝트를 명시할 때 yaml파일에서 spec을 정의해준다.

그 때 selector는 어떤 것을 가리킬까?

다 똑같은 오브젝트를 가리키는 것인지?


예상

pod를 가리킬 것 같다.


행동

파드 - 레플리카셋 - 디플로이먼트 - 스테이트풀셋 - 데몬셋 - 서비스순으로 진행하겠습니다.

 

파드

apiVersion: batch/v1
kind: Job
metadata:
  name: hello
spec:
  template:
    # 이것이 파드 템플릿이다.
    spec:
      containers:
      - name: hello
        image: busybox
        command: ['sh', '-c', 'echo "Hello, Kubernetes!" && sleep 3600']
      restartPolicy: OnFailure
    # 여기가 파드 템플릿의 끝이다.

파드 템플릿(파드에 대한 명세서)에는 selector가 없습니다!


레플리카셋

apiVersion: apps/v1
kind: ReplicaSet
metadata:
  name: frontend
  labels:
    app: guestbook
    tier: frontend
spec:
  # 케이스에 따라 레플리카를 수정한다.
  replicas: 3
  selector:
    matchLabels:
      tier: frontend
  template:
    metadata:
      labels:
        tier: frontend
    spec:
      containers:
      - name: php-redis
        image: gcr.io/google_samples/gb-frontend:v3

공식문서 참조

파드를 식별하는데 사용된다.


디플로이먼트

apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-deployment
  labels:
    app: nginx
spec:
  replicas: 3
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:1.14.2
        ports:
        - containerPort: 80

디플로이먼트의 셀렉터 역시 파드의 레이블을 가리킨다.


스테이트풀셋

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" ]
      storageClassName: "my-storage-class"
      resources:
        requests:
          storage: 1Gi

스테이트풀셋 역시 파드의 레이블을 선택하는 역할을 한다.


데몬셋

apiVersion: apps/v1
kind: DaemonSet
metadata:
  name: fluentd-elasticsearch
  namespace: kube-system
  labels:
    k8s-app: fluentd-logging
spec:
  selector:
    matchLabels:
      name: fluentd-elasticsearch
  template:
    metadata:
      labels:
        name: fluentd-elasticsearch
    spec:
      tolerations:
      # this toleration is to have the daemonset runnable on master nodes
      # remove it if your masters can't run pods
      - key: node-role.kubernetes.io/master
        effect: NoSchedule
      containers:
      - name: fluentd-elasticsearch
        image: quay.io/fluentd_elasticsearch/fluentd:v2.5.2
        resources:
          limits:
            memory: 200Mi
          requests:
            cpu: 100m
            memory: 200Mi
        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

데몬셋 역시 파드 셀렉터의 역할을 한다.

 


서비스

서비스의 경우는 약간 달랐다.

일반적으로는 파드에 대한 접근으로 셀렉터를 사용하지만

 

파드 셀렉터 없이도 서비스를 정의할 수 있었다.

 

apiVersion: v1
kind: Service
metadata:
  name: my-service
spec:
  ports:
    - protocol: TCP
      port: 80
      targetPort: 9376

위와 같이 파드 셀렉터가 없을 경우에는

해당 엔드포인트 오브젝트가 자동으로 생성되지 않는다.

 

그럴 땐 수동으로 추가하여, 서비스를 실행 중인 네트워크 주소 및 포트에 서비스를

수동으로 매핑할 수 있다.

 

apiVersion: v1
kind: Endpoints
metadata:
  name: my-service
subsets:
  - addresses:
      - ip: 192.0.2.42
    ports:
      - port: 9376

수동으로 추가 해 준 모습

 

위의 예 에서 트래픽은 192.0.2.42:9376(TCP)로 라우팅된다.


결과

파드는 자기자신을 가리킬 순 없으니까 아무것도 없었다.

디플로이먼트,레플리카셋, 데몬셋,스테이트풀셋은 파드를 가리켰다.

서비스는 파드셀렉터를 사용할 수 도있고, 수동으로 명시해 줄 수 도있었다.

 


특이한 점이나 느낀 점

조금 헷갈렸는데 이렇게 찾아보고 정리를 하니까 확실하게 정리가 되었다.

반응형

'Kubernetes & Docker > 궁금한 것' 카테고리의 다른 글

쿠버네티스 볼륨(volume)에 대해서  (0) 2020.07.17
쿠버네티스 minikube status 명령어를 입력하면 나오는 kubelet, apiserver,kubeconfig에 대해서  (0) 2020.07.17
쿠버네티스 노드와 마스터 서버에 대해서(kubelet, kubeadm)  (0) 2020.07.17
쿠버네티스 서비스(service)의 노드포트(NodePort)의 포트가 겹쳤을 때 어떻게 될까?  (0) 2020.07.17
쿠버네티스 Deployment와 ReplicaSet에 대해서  (0) 2020.07.16
    정현수
    정현수
    깃허브 : https://github.com/junghyeonsu 개인 블로그 : https://junghyeonsu.com/ (양질의 글을 올리려고 항상 노력합니다.)

    티스토리툴바