출처: https://www.coursera.org/learn/google-kubernetes-engine/home/week/1

 

Coursera | Online Courses From Top Universities. Join for Free

1000+ courses from schools like Stanford and Yale - no application required. Build career skills in data science, computer science, business, and more.

www.coursera.org

출처: 구글 클라우드 스터디잼 (중급) 가이드라인(박찬성님)

강의명: Welcome to Getting Started with Google Kubernetes Engine

## 쿠버네티스란 What are Containers?

# 전통적인 과거의 서버 환경

 

어플리케이션은 베어메탈 (bare-metal) 서버에서 구동되었으므로 아래와 같은 셋업 과정이 필요
1. 하드웨어의 설치
2. OS 또는 커널 (kernel)의 설치
3. 어플리케이션 구동에 요구되는 수 많은 의존성에 대한 설치 및 관리
4. 어플리케이션을 이 모든것 위에 설치할 수 있음

문제점
: 이 같은 기나긴 일련의 셋업이 완료된 이후에도 필요한 지속적인 의존성 유지/관리 및 모든것에 대한 싱크를 맞추기가 어려움
  ⇒ 해결책으로, VMware가 하이퍼바이저 개념을 도입

 

 

# 하이퍼바이저에 의한 서버 환경

 

 

VMware 진영에서, 하드웨어를 하이퍼바이징 하기 위한 방법을 고안
하드웨어를 커널, 의존성, 어플리케이션 으로부터 분리시킨다는 의미

이를 위해서, "하드웨어 하이퍼바이저"라는 계층이 개발되었고, 하드웨어 윗단에 위치한 모든 계층들을 자유롭게 만들어 주었음
즉, 한 단계의 추상 계층이 도입

 

 

 

# 하이퍼바이저에 의한 서버 환경의 문제점 1

 

 

하나의 가상머신에, 여러개의 서로 다른 버전으로 운영되는 동일한 어플리케이션의 설치/구동이 불가능
⇒ 의존성 에러가 속출하고, 여러가지 충돌 상황이 발생

이 문제에 대하여, 여러개의 가상머신을 생성하는 것으로 이 문제를 해결하려고 노력

 

 

# 하이퍼바이저에 의한 서버 환경의 문제점 2

 

무수히 많은 가상 머신을 생성한 후,
동일한 어플리케이션의 서로 다른 버전 또는 단순히 복제된 동일 버전을 설치/구동

의존성의 문제를 해결하지 못해서, 불가피하게 수 많은 가상머신을 만들어낼 수 밖에 없었다는 것이 문제
비용이 많이 들고, 모든면에서 비 효과적이고, 하드웨어 측면에서 또한 비 효과적임
⇒ 이 문제를 해결하기 위해 등장한 것이 Container

 

 

# 컨테이너에 의한 서버 환경

 

 

컨테이너 단위의 다른 수준의 추상화 방식
- 하드웨어 계층과의 분리
- {커널, 컨테이너 런타임} 계층과의 분리

즉, 위 두 가지 계층을 어떤 종류든지간에 어플리케이션과 어플리케이션에 필요한 의존성으로 부터 분리

매우 이식성이 좋고, 매우 효율적인 장점

 

 

# 컨테이너에 의한 서버 환경 - 개발자들에게 인기 있는 이유

 

어플리케이션은 어디에서든, 동일하게 동작
 - 개발, 테스트, 프로덕션 어떤 환경에서든
 - 베어메탈, 가상머신, 클라우드 어떤 환경에서든

패키지화된 어플리케이션은 개발 싸이클의 속도를 빠르게 회전시킴
 - 애자일한 생성과 배포가 가능
 - 지속적인 통합/배포가 가능
 - 단일 파일의 복사만으로 이를 가능하게 해줌

마이크로서비스를 가능하게 해 주기 위한 방법을 제공:
 - 분석 가능성(introspectable), 격리성(isolated), 탄력성(elastic)

 

# 12년에 걸친 컨테이너의 역사

 

# 도커 오버뷰

 

도커 컨테이너와 이미지의 관계
 - 이미지: 일종의 실행가능한 컨테이너를 생성하는데 사용되는 템플릿
 - 컨테이너: 이미지 기반의 실제 실행가능한 이미지 인스턴스

왼쪽 그림과 같이, ubuntu 라는 생성된 이미지는건드릴 수 없는 Read Only 계층. 
인스턴스를 찍어내기 위한 템플릿이라고 생각해 보면 당연한 내용
이미지라는 템플릿으로부터 여러개의동일한 컨테이너라고 불리는 인스턴스를 찍어낼 수 있음.
⇒ 인스턴스가 되었기 때문에, Read Write 가능한 계층

 

+ Recent posts