본문 바로가기

반응형

가상 머신

(46)
[ 도커 / Docker ] 이미지 관리하기 도커(Docker)는 컨테이너화된 애플리케이션을 빌드하고 관리하는 데 사용되는 명령어들을 제공합니다.이 중 docker image 관련 명령어들은 도커 이미지의 빌드, 리스트, 삭제 및 정리에 관련된 작업을 수행합니다.주요 명령어는 다음과 같습니다:1. docker image build / docker builddocker image build 명령어는 Dockerfile을 사용하여 이미지를 빌드합니다. Dockerfile은 애플리케이션을 컨테이너 이미지로 패키징하는 데 필요한 명령어들을 정의한 텍스트 파일입니다.사용법docker image build [OPTIONS] PATH | URL | -주요 옵션-t, --tag : 빌드된 이미지에 태그를 지정합니다. 예를 들어, myimage:latest 형식으..
[ 도커 / Docker ] version, info 명령어 도커(Docker)는 컨테이너화된 애플리케이션을 개발, 배포 및 실행하기 위한 오픈 소스 플랫폼입니다.도커 명령어는 도커 환경을 관리하고 제어하는 데 사용됩니다.그중 docker version과 docker info 명령어는 도커 설치 및 환경에 대한 중요한 정보를 제공합니다.1. docker versiondocker version 명령어는 도커 클라이언트와 서버(데몬) 버전 정보를 출력합니다. 이 명령어는 도커의 버전 호환성 문제를 확인할 때 유용합니다.사용법docker version출력 예시Client: Docker Engine - Community Version: 20.10.7 API version: 1.41 Go version: go1.13.15 Git c..
[ 쿠베네티스 / Kurbernetes ] 컨트롤러에 대해서 알아보기 Kubernetes의 컨트롤러는 클러스터 상태를 원하는 상태로 유지하기 위해 사용되는 주요 컴포넌트입니다.컨트롤러는 클러스터의 현재 상태를 지속적으로 모니터링하고, 필요에 따라 조치를 취하여 원하는 상태를 유지합니다.Kubernetes에서 제공하는 다양한 유형의 컨트롤러는 각각 특정한 목적과 기능을 가지고 있습니다.주요 컨트롤러 타입은 다음과 같습니다:1. ReplicationController목적: 지정된 수의 Pod 복제본이 항상 실행되도록 보장합니다.특징: 특정 수의 동일한 Pod를 유지하며, Pod가 죽거나 삭제되면 새로운 Pod를 생성합니다.예시:apiVersion: v1kind: ReplicationControllermetadata: name: my-replication-controllers..
[ 쿠버네티스 / Kurbernetes ] 서비스에 대해서 알아보기 Kubernetes의 서비스(Service)는 클러스터 내에서 실행되는 Pod에 대한 네트워크 접근을 관리하는 추상화된 리소스입니다.서비스는 일관된 방식으로 Pod에 접근할 수 있게 하여, 동적 환경에서도 안정적인 네트워크 통신을 가능하게 합니다.서비스는 여러 유형으로 제공되며, 각각의 기능과 특징이 다릅니다.1. Kubernetes 서비스의 주요 개념서비스 정의:서비스는 여러 Pod를 그룹화하여 하나의 논리적 단위로 묶습니다.각 서비스는 클러스터 내에서 고유한 IP 주소와 DNS 이름을 가집니다.레이블 셀렉터:서비스는 레이블 셀렉터를 사용하여 대상이 되는 Pod를 선택합니다.동일한 레이블을 가진 Pod는 서비스의 백엔드로 동작합니다.엔드포인트:서비스는 선택된 Pod의 IP 주소와 포트를 엔드포인트로 관..
[ 쿠버네티스 / Kurbernetes ] Pod의 라이프 사이클 Kubernetes에서 Pod의 라이프 사이클은 생성부터 종료까지 여러 단계를 거치며, 각 단계에서 Pod의 상태를 모니터링하고 관리할 수 있습니다.Pod의 라이프 사이클 단계는 다음과 같습니다:1. Pod의 라이프 사이클 단계Pending:Pod가 생성되었지만 아직 모든 컨테이너가 시작되지 않은 상태입니다.이는 스케줄러가 Pod를 적절한 노드에 할당하기 전 또는 이미지 다운로드, 자원 할당 등의 과정이 완료되지 않았을 때 발생합니다.Running:모든 컨테이너가 성공적으로 시작되어 실행 중인 상태입니다.Pod가 노드에 할당되고, 모든 초기화 단계가 완료된 후 이 상태로 전환됩니다.Succeeded:Pod 내의 모든 컨테이너가 성공적으로 종료된 상태입니다.각 컨테이너의 종료 상태가 0(정상 종료)일 때 ..
[ 쿠버네티스 / Kurbernetes ] Pod의 특징 Kubernetes에서 Pod는 가장 작은 배포 단위로, 하나 이상의 컨테이너를 그룹화한 것입니다.Pod는 애플리케이션의 인스턴스를 실행하는 기본 단위이며, 여러 컨테이너가 협력하여 하나의 애플리케이션 역할을 합니다.Pod의 주요 특징은 다음과 같습니다:1. Pod의 주요 특징단일 IP 주소:Pod는 클러스터 내에서 고유한 IP 주소를 갖습니다.같은 Pod 내의 모든 컨테이너는 이 IP 주소를 공유하며, 로컬 호스트 네트워킹을 사용해 통신합니다.공유 스토리지:Pod 내의 컨테이너들은 공유 스토리지를 사용할 수 있습니다.이를 통해 데이터 공유 및 협업이 용이합니다.단일 네트워크 네임스페이스:Pod 내의 모든 컨테이너는 같은 네트워크 네임스페이스를 공유합니다.이는 동일한 네트워크 인터페이스를 사용하며, 서로..
[ 쿠버네티스 / Kurbernetes ] K8s 구성하는 주요 프로세스 Kubernetes(K8s) 클러스터를 구성하는 코어 프로세스는 클러스터의 관리와 오케스트레이션을 담당하며, 주요 구성 요소는 다음과 같습니다:1. 마스터 노드 (Control Plane)마스터 노드는 클러스터를 관리하고 모든 노드 간의 조정을 담당합니다. 주요 구성 요소는 다음과 같습니다:kube-apiserver:Kubernetes API 서버로, 클러스터의 중앙 제어 부분입니다.클러스터의 모든 요청을 받아들이고, 유효성을 검사하며, RESTful API를 통해 다른 구성 요소와 통신합니다.etcd:분산 키-값 데이터베이스로, 클러스터의 상태 정보를 저장합니다.모든 마스터 노드 구성 요소와 클러스터의 상태를 공유하며, 고가용성을 위해 복제본을 유지합니다.kube-scheduler:새로 생성된 Pod를..
[ 쿠버네티스 / Kurbernetes ] 이미지가 컨테이너에서 실행되는 과정 순서대로 보기 쿠버네티스(Kubernetes)에서 이미지를 사용하여 컨테이너를 실행하는 과정은 여러 단계를 거쳐 이루어집니다.이 과정은 사용자가 kubectl 명령어를 실행하는 순간부터 시작하여, 실제로 컨테이너가 실행될 때까지의 일련의 작업을 포함합니다.아래는 그 순서를 설명한 내용입니다.1. 사용자가 명령어를 실행사용자가 kubectl 명령어를 사용하여 포드를 생성하거나, 배포(Deployment)를 생성합니다.kubectl apply -f deployment.yaml2. API 서버로 요청 전송kubectl 명령어는 Kubernetes API 서버(kube-apiserver)로 요청을 보냅니다. API 서버는 클러스터의 중앙 제어 포인트로, 모든 작업을 조정합니다.3. API 서버에서 요청 처리API 서버는 요청..

반응형