본문 바로가기

GitOps/Kubernetes

(5)
[Kubernetes] Controller 쿠버네티스 컨트롤러기본적인 개념은 여기에서ReplicaSet파드를 복제(replicate)하여 오토스케일링장애 대처 및 안정적 집합 유지AWS의 ASG와 같다.ReplicaSet 예제# replicaset.yaml# common APIapiVersion: apps/v1kind: ReplicaSetmetadata: name: replicasetspec: # 복제할 개수 replicas: 2 selector: # 해당 label을 기반으로 복제함 matchLabels: run: nginx-rs # 복제할 pod 정의 template: metadata: # label 지정. selector에서 참고함 labels: run: nginx-rs ..
[Kubernetes] Pod Pod기본 설명은 해당 글에 정리파드에 명령을 전달할 때 컨테이너를 지정하지 않으면 default 컨테이너가 수신Pod StatusPending: Control Plane에 생성 명령 전달 완료ContainerCreating: 특정 노드에 스케줄링되어 컨테이너 생성 중Running: 실행 중Completed: 작업 완료 (배치 작업을 수행하는 Pod 한정)Error: Pod에 에러 발생CrashLoopBackOff: 지속적으로 에러가 발생하여 crash 반복Pod 실행 예제# nginx pod 실행kubectl run nginx --image nginx# 생성 확인kubectl get pod# 파드에 명령 전달kubectl exec nginx -- apt-get update# 컨테이너에 진입kubectl..
[Kubernetes] 리소스 리소스기본 개념 및 리소스 종류들은 해당 글에서Manifest file클러스터에서 리소스를 정의하고 관리하는 데 사용되는 구성 파일주로 YAML로 작성됨파드, 서비스, 볼륨 등의 리소스 생성, 수정, 삭제 등의 방법 지시파일 구조apiVersion: API 버전 정보kind: 리소스 종류metadata: 리소스 메타데이터 (이름, 네임스페이스, 레이블 등)spec: 리소스 상세 정보 (컨테이너, 포트 등)pod manifest 예시apiVersion: v1kind: Podmetadata: name: nginx-pod labels: app: nginxspec: containers: - name: nginx image: nginx:1.14.2 ports: - containerPort: 80 M..
[Kubernetes] 클러스터 생성 ※ 세세한 설정을 생략하기 위해 GCP 환경에서 진행합니다.클러스터 생성 예제탐색 메뉴 - 쿠버네티스 엔진 - API 사용    탐색 메뉴 - 쿠버네티스 엔진 - 클러스터 - 만들기 - STANDARD 클러스터로 전환    위치 유형을 영역 us-central1-c로 지정하고 나머지는 기본값 유지 후 만들기   클러스터 생성 확인 완료 GCP CloudShell 환경 설정 예제우상단 터미널 아이콘 클릭 및 Project ID 복사클러스터 이름 및 위치 확인  # 현재 shell에 프로젝트 등록gcloud config set project # 현재 shell에 클러스터 등록gcloud container clusters get-credentials --region # 클러스터의 노드 확인 (3개 있어야 함..
[Kubernetes] 개념 배포 변화전통적인 배포: 애플리케이션을 물리 서버에서 실행. 고비용가상화된 배포: 단일 물리 서버가 VM으로 여러 개의 애플리케이션을 실행컨테이너 개발: VM과 유사하지만 확장성이 좋고 비용 절감, 속도 측면에서 유리함.쿠버네티스컨테이너화된 워크로드와 서비스를 관리하기 위한 플랫폼사람 대신 MSA의 수많은 컨테이너를 관리하는 플랫폼이미지 다운, 이미지 구동, 로드 밸런서 연결, 상태 유지 관리 등등의 일을 외주한다.YML파일인 Manifest를 명세해서 쿠버네티스에 전달하여 사용 가능쿠버네티스 아키텍처Cluster: Control Plane + Worker Nodes로 구성된 하나의 단위Control Plane(Master Node): 의사 결정. 정적인 개수가 정해져 있음Data Plane(Worker..