본문 바로가기

클라우드

(189)
쿠버네티스 Kubernetes Pod # Pod의 특징 파드안에는 하나의 독립적인 서비스를 구동할 수 있는 컨테이너들이 있다. 그 컨테이너들은 서비스가 연결될 수 있도록 포트를 가지고 있는데 한 컨테이너가 포트를 하나 이상 가질 수 있지만 한 파드내에서 컨테이너들끼리 포트가 중복될 수 없다. 이 두 컨테이너는 한 호스트로 묶여있다. Container1 에서 Container2로 접근할 때 localhost:8080으로 접근 가능하다. 파드가 생성될 때 고유의 IP 주소가 할당이 되는데, 쿠버네티스 클러스터내에서만 이 IP를 통해 파드에 접근할 수 있고, 외부에서는 이 IP로 접근할 수 없다. Pod에 문제가 생기면 System이 감지를 해서 파드를 삭제시키고 재생성하게 되고 IP는 변경이 된다. 더보기 apiVersion: v1 kind: ..
쿠버네티스 Kubernetes 개요 쿠버네티스는 서버 한 대는 Master로 사용하고 다른 서버들은 Node로 사용하여 Master에 여러 노드들을 연결한다. Master Node1 Node2 Node3 → 이것들이 묶여 하나의 클러스터(Cluster) 가 된다. # Master 쿠버네티스의 전반적인 기능들을 컨트롤하는 역할 # Node 자원을 제공하는 역할 만약 클러스터의 자원을 늘리고 싶다면 ? → 노드를 추가 하면 된다. # Namespace 클러스터안의 Namespace가 쿠버네티스 오브젝트들을 독립 된 공간으로 분리시켜준다. Namespace 안에는 쿠버네티스 최소 배포 단위인 Pod 들이 있고, Pod 들에게 외부로부터 연결이 가능하도록 IP를 할당해주는 서비스가 있다. (서로다른 Namespace에 있는 파드들에게는 연결할 수..
리눅스 → 도커 → 쿠버네티스 실습 시나리오 도커 환경과 쿠버네티스 환경에서 실제 앱을 구동시키는 실습 리눅스 → 도커 → 쿠버네티스 실습 시나리오 # 리눅스 1. 최초의 리눅스 서버에서 Hello world 라는 node.js 앱을 만들어 띄워 보기 → 리눅스에는 node.js를 실행할 수 있는 패키지가 깔려있어 앱이 구동이 된다. 2. 도커가 깔려있는 다른 서버에서 앞에서 만든 Hello world 앱을 가져올것 → 이 서버에는 node.js가 깔려있지 않기 때문에 실행 되지 않는다. # 도커를 이용해 컨테이너를 만든다. 1. 여러가지 컨테이너 이미지들을 공개적으로 올릴 수 있는 도커허브에서 node.js 이미지를 실행할 수 있는 컨테이너 이미지를 가져온다. 2. 복사해온 Hello world 앱을 하나의 컨테이너로 만든다. 더보기 Docker..
VM(가상머신) 과 Container(컨테이너)의 차이 # VM vs Container # VM 공통적으로 하나의 서버가 있고 한서버에는 어떤 운영 체제가 있건 HostOS (맥 OS, 리눅스, 마이크로소프트 윈도우) 가 올라간다. VM의 경우 호스트OS에 의해 VM을 가상화 시켜주는 하이퍼바이저(virtual box, Xen, KVM, VMware)들이 있다. 하이퍼 바이저를 사용하여 원하는 운영체제로 GuestOS를 올려 여러 VM을 만들 수 있다. GuestOS도 HostOS와 같이 하나의 OS를 독립적으로 가지고 있는것처럼 사용가능하다. 여러 어플리케이션들을 설치하고 각각의 서비스를 만들 수 있다. # 컨테이너 VM과 HostOS 까지 설치는 동일하다. 이 OS에 의해 컨테이너를 가상화 시켜주는 여러가지 소프트웨어들(docker, rkt, LXC)이 ..
쿠버네티스 Kubernetes의 등장 배경 # 쿠버네티스를 왜 사용하는가? 대규모의 서비스를 운영할 때 자원을 최대한 효율적으로 사용해야 비용적으로 유리하기 때문이다. 서버 자원을 효율적으로 사용하기 위해서는 가상화기술을 사용한다. # 쿠버네티스 등장 배경 시스템에 대한 꾸준한 개발을 통해 리눅스는 자원들을 격리해 프로세스들이 독립적인 환경에서 돌아가게 해주는 기술들( 리눅스 자원 격리 기술 : chroot, namespace, cgroup )이 있었지만 사용하기에 어려워 대중적으로 사용되지 않았다. 이 기술과는 별개로 vm 가상화 기술이 기업들은 물론 일반인들에게 까지 쉽게 vm을 가상화 할수있을정도로 발전해있었다. 2010년도에 rackspace 클라우드 기업과 미국 NASA에서 OpenStack 이라는 VM을 가상화 시켜주는 오픈소스가 등장..
kubernetes 에서 VM 생성하기 1 # 우분투에 microk8s를 이용하여 kubernetes 설치 --> 터미널 유지 더보기 $ sudo snap install microk8s --classic $ microk8s enable dashboard dns helm3 ingress prometheus registry $ sudo usermod -a -G microk8s user $ sudo chown -f -R user ~/.kube $ newgrp microk8s $ microk8s dashboard-proxy # 프록시 돌아가는 터미널 유지 -> config 넣어주기 # kubevirt 및 cdi 설치 -> 리소스들이 Running 상태에 오른것 확인 -> 리소스들이 Running 상태에 오른것 확인 더보기 $ sudo apt instal..
OpenStack 오픈스택 구성 예제
OpenStack 오픈스택 로드밸런서 # 로드밸런서 오픈스택은 서비스를 구성한 인스턴스를 다른 사용자들이 사용 할 수있도록 인스턴스 서비스를 제공해준다 인스턴스가 하나로 구성되는것보다는 여러개의 인스턴스로 구성되는것이 더 효율적이다 - 우리가 사용하는 서비스를 제공할 때에 하나의 시스템 (네트워크) 이용시 부하가 증가한다. 접근 제한이 발생 할 수 있다. - 시스템에 문제가 발생했을경우 서비스가 중단 될 수 있다 - HA 구성( 장애복구기능이 포함된 고가용성의 구성 )및 부하분산기능이 필요 => 로드밸런서 - 오픈스택에서의 로즈밸런서 : Neutron(네트워크) 서비스와 haproxy 프로세스등으로 기능 지원 -> Octavia 라고 부르는 로드밸런서 제공/별도의 가상머신을통해 부하분산 할 수있는 기능 # 기존 구성 외부에서 접속을 할 때 ..