본문 바로가기

개발 이야기/Kubernetes11

Kubernetes ConfigMap with Springboot 현업에서 Kubernetes 환경에 서버를 띄운다면 Configuration의 외부화는 필수적입니다. 당장에 생각나는건 아래와 같은 측면에서 유리하다고 볼 수 있을 것 같습니다. 민감 정보에 대한 보안 유지 환경마다 다른 변수와 애플리케이션 코드 디커플링 빠른 로컬 환경 구성 이번 포스팅에서는 쿠버네티스의 ConfigMap을 활용하여 애플리케이션의 환경변수를 외부화 하는 방법을 정리합니다. 목차 1. 기본 사용법 # configmap.yml apiVersion: v1 kind: ConfigMap metadata: name: api-server-config data: DATASOURCE_USERNAME: "root" DATASOURCE_PASSWORD: "1234" 먼저 ConfigMap은 위와 같이 구성.. 2024. 4. 10.
Telepresence 사용해보기 Telepresence는 MSA구조의 프로젝트에서 애플리케이션을 로컬에서 개발하기 위한 도구입니다. 개발자들이 Kubernetes cluster에서 서비스를 로컬 컴퓨터에서 실행하여 디버깅 및 테스트를 쉽게 할 수 있게 합니다. 즉, Cluster내에서만 접근 가능한 마이크로 서비스들을 로컬에서 쉽게 접근 할 수 있습니다. 이번 포스팅에서는 Telepresence로 로컬에 설치된 Kubernetes Cluster(Minikube) 연결해보겠습니다. 목차 1. Telepresence 설치 설치는 공식 홈페이지에 있는 문서를 참고하면 됩니다. 저는 Mac(M2) 랩탑이라서 아래와 같이 설치해줬습니다. # 다운로드 ~ sudo curl -fL https://app.getambassador.io/downloa.. 2024. 4. 3.
Kubernetes CronJob 실행 해보기 CronJob은 특정 잡을 주기적으로 실행 시킬 때 사용합니다. 주기적으로 파드를 띄워 프로그램을 실행/종료를 반복합니다. 이번 포스팅에서는 간단한 Cronjob을 실행해봅니다. 목차 1. cronjob.yml 작성 apiVersion: batch/v1 kind: CronJob metadata: name: hello spec: schedule: "* * * * *" jobTemplate: spec: template: spec: containers: - name: hello image: busybox args: - /bin/sh - -c - date; echo Hello Wolrd! restartPolicy: OnFailure 위 크론잡은 "* * * * *" 형식의 크론표현식을 사용합니다. # ┌───.. 2024. 3. 30.
Kubernetes HPA 설정하기 HPA는 Horizontal Pod Autoscaler를 뜻합니다. 워크로드에 따라 파드의 수평 확장/축소을 담당합니다. 최소 파드 수와 최대 파드 수를 설정하고, CPU 및 메모리의 사용량을 디플로이먼트에 기입하여야 합니다. 이번 포스팅에서는 간단한 예시를 통해 HPA 설정 방법을 정리합니다. 목차 1. HPA.yml 작성 apiVersion: autoscaling/v2 kind: HorizontalPodAutoscaler metadata: name: api-server spec: scaleTargetRef: apiVersion: apps/v1 kind: Deployment name: api-server minReplicas: 1 maxReplicas: 2 metrics: - type: Resourc.. 2024. 3. 30.
Docker Image를 Minikube 로드하기 Docker Image를 Minikube로 로드 하는 과정에서 아래 에러가 발견됬습니다. ~ minikube image load api-exam:0.0.1 ❌ Exiting due to GUEST_IMAGE_LOAD: Failed to load image: save to dir: caching images: caching image "/Users/myuserid/.minikube/cache/images/arm64/api-exam_0.0.1": write: unable to calculate manifest: blob sha256:00fd5b12683afed295344689d9cd313043ecd10a660da04f9c48484e10095a09 not found GUEST_IMAGE_LOAD: Failed.. 2024. 3. 24.
ArgoCD를 통해서 Application 배포 지난번 포스팅에서 ArgoCD를 구축하는 방법을 정리했습니다. 이어서 Application을 만들고 Git Ops 워크플로우를 적용해봅시다. 1. Git Ops 워크플로우란 GitOps 워크플로우란 Git Repository를 통해 Application 배포 및 관리를 수행하는 것을 뜻합니다. Application의 상태와 구성이 Git 저장소에 정의되어있으며, 변경사항이 Commit 되면 ArgoCD를 통해서 Application 배포가 이뤄지게 됩니다. 위와 같은 워크플로우 적용을 위해서는 Git Repository에 저장될 정의가 중요할 것입니다. 여기서 kustomize라는 쿠버네티스의 오브젝트 선언형 관리 방법을 적용해 볼 수 있습니다. 2. Kustomize로 Application 정의 여기.. 2024. 3. 24.
Kubernetes, ArgoCD 설치 해보기(with Minikube) ArgoCD는 쿠버네티스 클러스터에 쉽게 애플리케이션을 배포 할 수 있게 해주는 유용한 도구입니다. 저도 실무에서 사용하고 있는데요. 운영을 하고 있는건 아니고 개발자로서 사용자 입장입니다. ArgoCD가 없는 업무 환경은 상상하기 싫을 정도로 만족하며 쓰는 도구입니다.👍 아래와 같은 주요 특징이 있습니다. 사용자 친화적 UI 제공 Git repository와 연동 및 지속 배포(Continuous Delivery) 구성 손쉬운 쿠버네티스 CLI(Command Line Interface) 사용 이번 포스팅에서는 ArgoCD를 설치하는 과정을 정리합니다. Docker, Minikube가 설치되어 있어야합니다. 1. 설치 먼저 설치하기 전에 Namespace를 하나 만들어 줍니다. ~ kubectl crea.. 2024. 3. 9.
kubectl 자주 쓰는 명령어 정리 kubectl은 쿠버네티스 클러스터 사용을 위한 CLI(Comand Line Interface)입니다. 이번 포스팅에서는 실무에서 자주 사용하는 kubectl을 정리해봅니다. 1. 설치 만약 로컬 환경에 minikube 설치 또는 kubernetes on docker desktop 활성화가 되어있다면 따로 설치할 필요가 없습니다. 만약 쿠버네티스 클러스터가 외부에 있다면 공식 홈에서 설치 가능합니다. 설치가 완료되었다면 아래처럼 로컬 PC에서 kubectl 사용 가능합니다. ~ kubectl version Client Version: v1.29.2 Kustomize Version: v5.0.4-0.20230601165947-6ce0bf390ce3 Server Version: v1.28.3 2. 클러스터 .. 2024. 3. 9.
Kubernetes, Ingress 구성 해보기 Ingress는 쿠버네티스 클러스터 외부에서 내부 서비스로 HTTP와 HTTPS 경로를 노출하기 위해 사용합니다. 위 핵심 기능 외에도 Ingress 리소스에 라우팅 규칙을 정의하여 로드밸런서로서의 역할을 할 수도 있습니다. 이번 포스팅에서는 Minikube를 통해 Ingress를 설정하는 방법을 정리합니다. 그 전에 Minikube 및 간단한 Service, Deployment는 구성되어 있다고 가정합니다. 이전 포스팅👉 Minikube 설치: https://basketdeveloper.tistory.com/104 Service 구성: https://basketdeveloper.tistory.com/105 1. Ingress 설치 아래처럼 minikube 명령어를 통해 ingress를 클러스터에 설치해.. 2024. 3. 8.
Kubernetes, Deployment와 Service 구성 해보기 배포 (Deployments): 컨테이너의 롤아웃 및 업데이트를 관리하며, 응용 프로그램 복제본 및 이미지 버전의 원하는 상태를 유지합니다. 롤링 업데이트 및 롤백을 지원합니다. 실제 Application 구성 단위가 됩니다. 서비스 (Services): 클러스터 내부에서 응용 프로그램 컨테이너에 대한 네트워킹 및 액세스를 제공하며, 아래와 같은 타입이 있습니다. ClusterIP: 쿠버네티스 클러스터 내부에서만 통신을 허용합니다. 운영환경에서 백엔드 서버 구성에 사용됩니다. NodePort: 특정 포트를 매핑 시킵니다. 그리고 클러스터 외부에서 해당 포트로 접근을 허용합니다. 운영환경에서는 권장하지 않습니다. Loadbalancer: 클라우드 제공업체에서 제공하는 로드 밸런서를 사용하여 서비스를 외부로.. 2024. 3. 2.
Minikube 설치해보기 Minikube는 로컬 컴퓨터에서 Kubernetes 클러스터를 실행하는 도구로, 개발 및 테스트 목적에 유용합니다. 컴퓨터 내 가상 머신 안에 단일 노드 Kubernetes 클러스터를 설정하여 전체 규모의 클러스터나 클라우드 인프라 없이도 Kubernetes를 실험할 수 있게 해줍니다. 해당 포스팅에서는 Minikube를 로컬 PC에 설치하는 방법을 정리합니다. 먼저 저의 로컬 PC 환경은 아래와 같습니다. 사전에 도커가 받드시 설치되어 있어야합니다. MacOS Sonoma (칩: M2) Docker version 25.0.3 (Docker Desktop on Mac 사용 중) 1. 설치 MacOS에서는 Homebrew가 설치되어 있다면, 아래 명령어로 간단히 설치 가능합니다. 터미널을 열러 brew.. 2024. 3. 2.