본문 바로가기

devops/k8s

(5)
[Kubernetes] private 저장소의 이미지를 가져오는 법 kubernetes를 공부하기 위해서 진행하는 프로젝트에서 private 저장소의 이미지를 가져와서 배포를 해야하는 상황을 마주하게 되었다. 그 동안은 public 이미지를 통해서 배포를 구성해왔기 때문에 크게 고민하지 않고 사용했던 기능이었지만 이번 기회를 통해서 공부하게 되었다.로그인을 위한 Secret 생성하기도커 허브에 접속하기 위해서 필요한 아이디와 비밀번호 정보를 기반으로 비밀을 생성할 수 있다. 만약 도커 허브가 아니라 다른 이미지 저장소를 사용한다면 docker-server의 파라미터를 알맞게 수정해서 사용하면 된다.kubectl create secret docker-registry regcred --docker-server=https://index.docker.io/v1/ --docker..
Go template을 이용한 helm value.yaml 값 매핑하는 방법 헬름을 이용해서 배포 환경을 문서화하는 작업을 할 때, 배포하는 서비스의 구성요소 설정을 어떻게 구성하는 것이 좋은지에 대한 고민이 많이 들었다. 처음에는 nginx의 헬름차트 구성이 어떻게 되어있는지를 살펴보고 단일 차트에 대한 설정에 대해서 감을 잡고 go template을 어떻게 사용하는지에 대한 예시를 보면서 학습을 하였다. go를 사용하지 않아서 처음 보는 템플릿 표현 방식에 대해서 정리를 해보았다.Go template을 이용한 설정값 매핑하기헬름의 차트의 값들은 value.yaml에 정의된다. 정의 값은 go template을 이용해서 templates 안에 존재하는 쿠버네티스 컴포넌트에 반영된다. 프로젝트를 진행하면서 알게된 helm에서 Go template 사용법을 몇가지 소개한다.1:1 ..
Statefulset과 Deployment 차이점이란? helm을 통해서 kafka를 배포했는데 배포된 리소스의 타입이 statefulset이었다. 왜 deployment을 안쓰고 statefulset을 사용을 하는지 궁금해져서 관련된 내용을 찾아보게 되었다.StatefulSet이란?공식문서에서는 애플리케이션의 스테이트풀을 관리하는데 사용하는 워크로드 API 오프젝트라고 소개한다. 즉, 상태를 안정적으로 관리할 수 있는 리소스라는 것이다.스테이트 풀셋은 다음과 같은 요구 사항이 필요한 어플리케이션에 적합하다고 한다.안정적이고 고유한 네트워크 식별자가 필요한 경우안정적이고 지속적으로 유지가 필요한 스토리지가 필요한 경우순차적인, 정상 배포(graceful deployment)와 스케일링이 필요한 경우순차적인 자동 롤링 업데이트가 필요한 경우구체적인 사례와 연관..
[k8s] 쿠버네티스를 다루면서 마주친 오류/실수 보호되어 있는 글입니다.
[k8s] 가상머신 환경에서 클러스터 구성하기 Forwarding IPv4 and letting iptables see bridged traffic 리눅스의 netfilter 를 이용하여 네트워크를 다루는데 k8s가 사용하기 때문에 해당 설정을 하는 것 Container Runtimes Note: Dockershim has been removed from the Kubernetes project as of release 1.24. Read the Dockershim Removal FAQ for further details. You need to install a container runtime into each node in the cluster so that Pods can run there. This page outlines what kubern..