kubernetes 클러스터를 관리하다 보면 수많은 사용자와 애플리케이션이 동시에 사용하는것이 일반적이다. 사내 개발 조직에 속해 있는 개발자들이 사용하는 경우도 있고 클러스터를 관리하는 인프라 관리자, 애플리케이션들이 있다. 이렇게 동시에 많은 사용자가 있을 경우 보안을 고려해야하는데 그중에서 사용하는 것이 RBAC(Role Based Access Control)를 기반으로 하는 Service Account라는 기능이 있다. 이뿐만 아니라 role기반으로 rolebinding이라는 기능으로 그룹을 나누어 관리도 가능하다. 또한, 특정 namespace나 특정 자원에 대한 전용 권한만 추가할 수 있도록 관리하는 기능도 제공한다.
kubernetes는 여러 가지의 컴포넌트들로 이루어져 있는데, kube-apiserver, kube-controller, kube-scheduler, etcd 등이 있다.
이러한 컴포넌트 중에서 가장 많이 사용하는 컴포넌트가 k8s API 서버에 해당하는 kube-apiserver라는 컴포넌트이다. 대부분 api를 통하여서 쿠버네티스 기능들을 사용하게 되는 구조이다.
예를 들어 kubectl 명령어를 이용해서 쿠버네티스 기능을 실행하면 쿠버네티스 내부에서는 다음과 같이 처리 됩니다.
사용자가 kubectl 명령어를 날리게 되면 k8s API 서버의 HTTP 핸들러에 요청을 전송한다. API 서버는 사용자가 k8s 사용자를 확인(Authentication) 및 해당 명령어(기능)를 실행할 권한(Authorizaition)이 있는지 확인한다. Authentication(인증)과 Authorization(인가)에 인증서, third party 인증(Oauth 등) 등과 같은 다른 방법을 사용될 수 있다. 그 다음, Admission Controller라는 별도의 단계를 거쳐서 요청 받은 기능을 수행한다.
대부분 따로 권한 설정을 부여하지 않지만 명령어가 실행되는 것을 알수 있다. 이 부분은 k8s를 설치할 때 설치 도구가 자동으로 kubeconfig라는 파일을 통해 kubectl이 관리자 권한을 갖도록 설정해 두기 때문이다. 파일의 위치는 ~/.kube/config 에서 확인할 수 있다.
apiVersion: v1
clusters:
- cluster:
certficate-authority-data: ***
server: https://10.100.0.20:6443
name: kubernetes
contexts:
- context:
cluster: kubernetes
user: kubernetes-admin
name: kubernetes-admin@kubernetes
current-context: kubernetes-admin@kubernetes
preferences: {}
users:
- name: admin
user:
client-certificate-data: ***
client-key-data: ***
위는 ~/.kube/config 파일 내용이며 저장된 설정을 읽어 들여 k8s 클러스터를 제어한다. 이 파일에 저장된 내용중에 users라는 항목에 인증을 위한 데이터가 설정되어 있다. client-certificate-data와 client-key-data에 base64로 인코딩된 인증서이며, 이 키 쌍은 k8s에서 최고 권한 cluster-admin을 갖는다. 그래서 모든 명령어를 사용할 수 있다.
서비스 어카운트는 권한 관리하기 위한 k8s 오브젝트 중 하나이다. 한명의 사용자 또는 application에 해당한다고 보면 쉽다.
일단 namespace 속하는 오브젝트이며 serviceaccount 또는 sa라는 이름(명령어)로 사용할 수 있다.
RKE2 클러스터 구축 (0) | 2024.10.25 |
---|---|
Kubernetes 설치 - disconnected network (controle-plane) (0) | 2024.10.25 |
Elastic Cloud on Kubernetes 설치 (0) | 2022.10.23 |
RBAC Authorization (0) | 2021.10.20 |
K8S ingress에 대하여 (0) | 2021.06.24 |
댓글 영역