일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- Kafka
- hive
- 간단
- Docker
- SpringBoot
- 자동
- Redis
- java
- spring
- 로그인
- Zeppelin
- 설정
- 레디스
- Mac
- EMR
- 클러스터
- Cluster
- login
- config
- 젠킨스
- 자바
- aws
- ec2
- 머신러닝
- Jenkins
- 예제
- redash
- gradle
- vue
- fastcampus
- Today
- Total
코알못
[Kubernetes & Docker] Kuberneties 구성 본문
이번 시간에는 구글 쿠버네티스 클러스터 구성하도록 한다!
아래와 같이 google cloud 에 접속한뒤 콘솔에서 클러스터 만들기를 선택한다.
자동 관리가 아닌 사용자가 직접 관리 하도록 할 예정이며 아래 화면과 같이 클릭한다.
원하는 클러스터명을 기재한다.
노드의 경우 3개로 구성 하도록 한다.
10분 정도 기다리면 클러스터가 생성 되며 초기 셋팅을 위해 연결을 클릭한다.
gcloud 라는 google CLI 를 이용하여 클라우드 구성 가능하며 화면에 나오는 명령어를 복사한다.
만약 shell이 로컬에 설치되어 있지 않다면 구글에서 브라우저 shell 인 cloud shell 제공 하고 있어 제공하는 쉘을 이용해도 된다.
cloud shell 을 이용하면 해당 쉘에 gcloud, kubectl 이 설치 되어 있어 설치 할 필요 없으며
로컬의 쉘을 이용한다면 gcloud, kubectl을 설치 해야 하므로 아래 사이트 참고하여 먼저 설치 한다.
- gcloud 설치 관련 사이트 : https://cloud.google.com/sdk/docs/install?hl=ko
로컬에 압축 파일 다운로드후 아래 쉘 파일을 실행한다.
// 설치
$ ./google-cloud-sdk/install.sh
// 초기화 (사용하고 있는 프로젝트, 계정을 선택한다.)
$ ./google-cloud-sdk/bin/gcloud init
- kubectl 설치 관련 사이트 : https://kubernetes.io/ko/docs/tasks/tools/install-kubectl-macos/#install-with-homebrew-on-macos
// 설치
$ brew install kubectl
// 확인
$ kubectl version --client
Client Version: version.Info{Major:"1", Minor:"22", GitVersion:"v1.22.5", GitCommit:"5c99e2ac2ff9a3c549d9ca665e7bc05a3e18f07e", GitTreeState:"clean", BuildDate:"2021-12-16T08:38:33Z", GoVersion:"go1.16.12", Compiler:"gc", Platform:"darwin/amd64"}
kuberneties 클러스터 설정을 진행해야 하며, 아래 설정 관련 파일 확인시 아무 설정이 되어 있지 않다.
$ cat ~/.kube/config
처음 UI 에서 제공한 gcloud 명령어를 호출하여 클러스터 설정 진행한다.
만약 정상적으로 설정 됐다면 아래와 같이 클러스터 정보 확인 가능하다.
$ cat ~/.kube/config
apiVersion: v1
clusters:
- cluster:
certificate-authority-data: abcd <인증서 base64로 인코딩한 데이터>
server: https://35.1.1.2 <마스터 노드의 API Server 주소>
name: gke_reference-lens-1234_asia-east1-a_corin-cluster
contexts:
- context:
cluster: gke_reference-lens-1234_asia-east1-a_corin-cluster
user: gke_reference-lens-1234_asia-east1-a_corin-cluster
name: gke_reference-lens-1234_asia-east1-a_corin-cluster
current-context: gke_reference-lens-1234_asia-east1-a_corin-cluster
kind: Config
preferences: {}
users:
- name: gke_reference-lens-1234_asia-east1-a_corin-cluster
user:
exec:
apiVersion: client.authentication.k8s.io/v1beta1
command: gke-gcloud-auth-plugin
installHint: Install gke-gcloud-auth-plugin for use with kubectl by following
https://cloud.google.com/blog/products/containers-kubernetes/kubectl-auth-changes-in-gke
provideClusterInfo: true
kubectl 명령어를 호출해보면 접속 까지는 잘 되는것을 볼 수 있다.
$ kubectl get pod
No resources found in default namespace.
끝!
# 오류
1) permission 오류
- 원인 : 클러스터에 권한이 없음
ResponseError: code=403, message=Required "container.clusters.get" permission(s)
- 해결 : gcloud init 명령어로 해당 클러스터, 유저로 정상 셋팅 했는지 재 확인한다. 저자의 경우 로그인을 잘못했다.
2) 플러그인 미 설치 이슈
- 원인 : 플러그인 gke-gcloud-auth-plugin 미 설치
Unable to connect to the server: getting credentials: exec: executable gke-gcloud-auth-plugin not found
It looks like you are trying to use a client-go credential plugin that is not installed.
To learn more about this feature, consult the documentation available at:
https://kubernetes.io/docs/reference/access-authn-authz/authentication/#client-go-credential-plugins
Install gke-gcloud-auth-plugin for use with kubectl by following https://cloud.google.com/blog/products/containers-kubernetes/kubectl-auth-changes-in-gke
- 해결 : 플러그인 설치
$ gcloud components install gke-gcloud-auth-plugin