Kubernetes-네임 스페이스

네임 스페이스는 리소스 이름에 대한 추가 자격을 제공합니다. 이는 여러 팀이 동일한 클러스터를 사용하고 이름 충돌 가능성이있을 때 유용합니다. 여러 클러스터 사이의 가상 벽이 될 수 있습니다.

네임 스페이스의 기능

다음은 Kubernetes에서 네임 스페이스의 중요한 기능 중 일부입니다.

  • 네임 스페이스는 동일한 네임 스페이스를 사용하여 포드 간 통신을 지원합니다.

  • 네임 스페이스는 동일한 물리적 클러스터 위에 위치 할 수있는 가상 클러스터입니다.

  • 팀과 환경을 논리적으로 분리합니다.

네임 스페이스 생성

다음 명령은 네임 스페이스를 만드는 데 사용됩니다.

apiVersion: v1
kind: Namespce
metadata
   name: elk

네임 스페이스 제어

다음 명령은 네임 스페이스를 제어하는 ​​데 사용됩니다.

$ kubectl create –f namespace.yml ---------> 1
$ kubectl get namespace -----------------> 2
$ kubectl get namespace <Namespace name> ------->3
$ kubectl describe namespace <Namespace name> ---->4
$ kubectl delete namespace <Namespace name>

위의 코드에서

  • 명령을 사용하여 네임 스페이스를 만듭니다.
  • 사용 가능한 모든 네임 스페이스가 나열됩니다.
  • 명령에 이름이 지정된 특정 네임 스페이스를 가져옵니다.
  • 이것은 서비스에 대한 완전한 세부 사항을 설명합니다.
  • 이렇게하면 클러스터에있는 특정 네임 스페이스가 삭제됩니다.

서비스에서 네임 스페이스 사용-예

다음은 서비스에서 네임 스페이스를 사용하기위한 샘플 파일의 예입니다.

apiVersion: v1
kind: Service
metadata:
   name: elasticsearch
   namespace: elk
   labels:
      component: elasticsearch
spec:
   type: LoadBalancer
   selector:
      component: elasticsearch
   ports:
   - name: http
      port: 9200
      protocol: TCP
   - name: transport
      port: 9300
      protocol: TCP

위 코드에서 우리는 서비스 메타 데이터 아래에서 이름이 다음과 같은 동일한 네임 스페이스를 사용하고 있습니다. elk.