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.