SlideShare a Scribd company logo
1 of 22
Download to read offline
모두의 쿠버네티스
2020.07.02 29CM 백엔드 조은우
알아야 할 배경 지식(1) 애플리케이션 실행 환경의 변화
이미지 출처: kubernetes.io
알아야 할 배경 지식(2-1) 컨테이너 기술
! 프로세스 단위의 격리 환경
! 호스트 커널을 공유하고 애플리케이션을 실행하기 위한 라이브러리와 파일만 존재
! VM에 비해 사이즈가 작아 배포가 빠르고, 성능 손실이 거의 없다
! 다양한 컨테이너 런타임 기술 중 도커(Docker)가 사실상 표준
알아야 할 배경 지식(2-2) 도커 이미지와 컨테이너
! 도커 이미지
○ 컨테이너를 실행하기 위해 필요한 모든 파일들을 캡슐화한 패키지
○ `Dockerfile`을 기반으로 각 단계마다 레이어(Layer)로 구성되며,

각 레이어는 이전 레이어를 상속한다
○ 각 레이어는 읽기 전용이며, 컨테이너가 실행되면 마지막에 쓰기 레이어 추가
! 도커 컨테이너
○ 1개의 컨테이너에는 1개의 프로세스를 실행하는 것이 원칙 (PID 1)
○ 컨테이너를 종료하면 쓰기 레이어도 사라진다
알아야 할 배경 지식(2-3) Dockerfile
# Dockerfile
FROM python:slim-buster
ENV PYTHONPATH /bar
ENV HOME /usr/src/app
WORKDIR ${HOME}
COPY server.py ${HOME}/server.py
CMD ["python", "server.py"]
읽기 전용 레이어
쓰기 가능 레이어
$ docker build -t [저장소 이름]/[이미지 이름]:[태그] .
알아야 할 배경 지식(2-3) 도커 컨테이너로 서비스를 한다는 것은
! 하나의 도커 이미지 안에 서비스 운영에 필요한 모든 것들이 들어있다
! 서비스 운영 환경과 개발 환경의 느슨한 결합
! 쉽고 빠른 배포
! 시스템 의존성을 쉽게 업그레이드
! 확장이 쉽다 (스케일 아웃)
! 효율적인 시스템 자원 활용 (CPU limit / Memory limit)
! 가상 머신(vm)보다 나은 성능
알아야 할 배경 지식(3) 컨테이너화된 애플리케이션 관리 문제
아… 또 컨테이너 맛이 갔네
계속 보고 있을 수도 없고…
직접

재실행
용사님
일어나세요
쿠버네티스란 무엇인가?
쿠버네티스는 컨테이너화된 워크로드와 서비스를 관리하기 위한 이식할 수 있고,

확장 가능한 오픈소스 플랫폼으로, 선언적 구성과 자동화를 모두 지원한다.
쿠버네티스는 크고 빠르게 성장하는 생태계를 가지고 있다.
출처: kubernetes.io
쿠버네티스란 무엇인가?
! 컨테이너화된 애플리케이션을 실행하고, 관리하는 역할
! 요구하는 애플리케이션 상태를 나타내는 선언형 정의
! 애플리케이션의 현재 상태와 요구한 상태를 일치 시켜주는 역할
! 애플리케이션의 운영자 책임과 클러스터 운영자의 책임 분리
쿠버네티스가 하지 않는 것들
! Platform as a Service(PaaS)가 아니다
! 배포, 스케일링, 로드 밸런싱, 로깅, 모니터링 등의 기능을 제공할 수 있지만,
선택적으로 사용한다
! CI/CD를 위한 플랫폼이 아니다 

즉, 소스 코드를 배포하지 않으며 애플리케이션을 빌드하지 않는다
! 머신(서버)의 설정, 유지보수, 자동 복구 시스템을 제공하지 않는다
! 단순한 오케스트레이션 시스템이 아닌 독립적이고 조합 가능한 제어 프로세
스들로 구성된다
쿠버네티스 클러스터 전체 구성
이미지 출처: kubernetes.io
쿠버네티스 클러스터 - 컨트롤 플레인
! etcd
○ 쿠버네티스 클러스터의 모든 데이터를 담
고 있는 Key-Value 저장소
! kube-api-server
○ 쿠버네티스 클러스터의 허브로서 클라이
언트와 etcd에 저장된 데이터 사이의 상
호 작용을 중개
○ 사용자(운영자), 클러스터 내 구성 요소,
외부 컴포넌트가 서로 통신할 수 있는
HTTP API 제공
쿠버네티스 클러스터 - 컨트롤 플레인
! kube-scheduler
○ 새로운 POD를 어떤 워커 노드에 실행 시
킬지 선택하는 역할
! kube-controller-manager
○ API 서버를 통해 클러스터의 다양한 컴포
넌트들의 상태를 감지하고, 원하는 상태로
만드는 역할
○ 다양한 컨트롤러가 하나로 패키징되어 단
일 프로세스 내에서 실행된다
쿠버네티스 클러스터 - 워커 노드
! kubelet
○ 모든 워커 노드에서 실행되는
에이전트
○ 컨테이너를 생성, 삭제하고 상
태를 모니터링, 마스터 노드와
통신을 담당
! kube-proxy
○ 모든 워커 노드마다 실행되는
네트워크 프록시
○ 다른 POD 간의 네트워크 통신
과 클러스터 바깥에서 POD로
네트워크 통신을 할 수 있게
쿠버네티스 오브젝트 - POD
! 쿠버네티스에서 가장 작은 기본 실행 단위
! 1개 이상의 컨테이너로 구성된 컨테이너의 집합
! POD 안에 모든 컨테이너는 서로 같은 네트워크
와 볼륨을 공유
! POD는 고유한 가상 IP를 할당
! POD 내부 컨테이너끼리 localhost로 통신 가능
(서로 다른 포트 사용시)
쿠버네티스 오브젝트 - POD Manifest
# example_pod.yaml
apiVersion: v1
kind: Pod
metadata:
labels:
app: webserver
name: example-app
spec:
containers:
- image: nginx
name: example-app
$ kubectl create -f example_pod.yaml
$ kubectl run example-app --image nginx --restart=Never
※ 매니페스트 작성 없이 바로 만들기
쿠버네티스 오브젝트 - Service
! POD의 고유 IP는 바뀔 수 있다
! 클러스터 내외부에서 POD로 접근하기 위한
영속적인 방법
! 여러 POD에 쉽게 접근할 수 있도록 고유한
도메인 이름을 부여
! 여러 POD에 요청을 분산하는 로드 밸런서 기
능 수행
! 접근 방식에 따라 ClusterIP, NodePort,
LoadBalancer 타입으로 나뉜다
;
쿠버네티스 오브젝트 - ReplicaSet
! 정해진 개수(replicas) 만큼 동일한 POD
가 항상 실행되도록 관리
! 워커 노드 장애 등의 이유로 POD를 사용
할 수 없다면 다른 노드에 POD를 다시 생
성
! 실제 운영 환경에서 ReplicaSet으로 직접
사용하는 경우는 거의 없다
쿠버네티스 오브젝트 - Deployment
! ReplicaSet의 상위 개념이지만 같은 역할
! 애플리케이션의 업데이트와 배포를 더욱
편하게 하기 위함
! ReplicaSet의 변경 사항을 저장하는
Revision을 남겨 롤백이 가능
! 무중단 서비스를 위해 POD의 롤링 업데이
트 가능
쿠버네티스 오브젝트 - Deployment Manifest
# example_deployment.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: example-app
name: example-app
spec:
replicas: 3
selector:
matchLabels:
app: webserver
template:
metadata:
labels:
app: webserver
spec:
containers:
- image: nginx
name: nginx
$ kubectl create -f example_deployment.yaml
$ kubectl create deployment example-app --image nginx
※ 매니페스트 작성 없이 바로 만들기
쿠버네티스 빠르게 시작하기
Minikube
모두의 쿠버네티스 마침
감사합니다

More Related Content

What's hot

쿠버네티스의 이해 #1
쿠버네티스의 이해 #1쿠버네티스의 이해 #1
쿠버네티스의 이해 #1상욱 송
 
Kubernetes presentation
Kubernetes presentationKubernetes presentation
Kubernetes presentationGauranG Bajpai
 
Kubernetes: A Short Introduction (2019)
Kubernetes: A Short Introduction (2019)Kubernetes: A Short Introduction (2019)
Kubernetes: A Short Introduction (2019)Megan O'Keefe
 
Deploying your first application with Kubernetes
Deploying your first application with KubernetesDeploying your first application with Kubernetes
Deploying your first application with KubernetesOVHcloud
 
Kubernetes Helm: Why It Matters
Kubernetes Helm: Why It MattersKubernetes Helm: Why It Matters
Kubernetes Helm: Why It MattersPlatform9
 
Kubernetes Deployment Strategies
Kubernetes Deployment StrategiesKubernetes Deployment Strategies
Kubernetes Deployment StrategiesAbdennour TM
 
Hands-On Introduction to Kubernetes at LISA17
Hands-On Introduction to Kubernetes at LISA17Hands-On Introduction to Kubernetes at LISA17
Hands-On Introduction to Kubernetes at LISA17Ryan Jarvinen
 
Kubernetes #1 intro
Kubernetes #1   introKubernetes #1   intro
Kubernetes #1 introTerry Cho
 
Architecture Overview: Kubernetes with Red Hat Enterprise Linux 7.1
Architecture Overview: Kubernetes with Red Hat Enterprise Linux 7.1Architecture Overview: Kubernetes with Red Hat Enterprise Linux 7.1
Architecture Overview: Kubernetes with Red Hat Enterprise Linux 7.1Etsuji Nakai
 
KubeVirt (Kubernetes and Cloud Native Toronto)
KubeVirt (Kubernetes and Cloud Native Toronto)KubeVirt (Kubernetes and Cloud Native Toronto)
KubeVirt (Kubernetes and Cloud Native Toronto)Stephen Gordon
 
Docker and kubernetes_introduction
Docker and kubernetes_introductionDocker and kubernetes_introduction
Docker and kubernetes_introductionJason Hu
 
Intro to Helm for Kubernetes
Intro to Helm for KubernetesIntro to Helm for Kubernetes
Intro to Helm for KubernetesCarlos E. Salazar
 
Getting Started with Kubernetes
Getting Started with Kubernetes Getting Started with Kubernetes
Getting Started with Kubernetes VMware Tanzu
 
Docker and kubernetes
Docker and kubernetesDocker and kubernetes
Docker and kubernetesDongwon Kim
 

What's hot (20)

DevOps with Kubernetes
DevOps with KubernetesDevOps with Kubernetes
DevOps with Kubernetes
 
Kubernetes 101
Kubernetes 101Kubernetes 101
Kubernetes 101
 
쿠버네티스의 이해 #1
쿠버네티스의 이해 #1쿠버네티스의 이해 #1
쿠버네티스의 이해 #1
 
Kubernetes presentation
Kubernetes presentationKubernetes presentation
Kubernetes presentation
 
Kubernetes: A Short Introduction (2019)
Kubernetes: A Short Introduction (2019)Kubernetes: A Short Introduction (2019)
Kubernetes: A Short Introduction (2019)
 
Deploying your first application with Kubernetes
Deploying your first application with KubernetesDeploying your first application with Kubernetes
Deploying your first application with Kubernetes
 
Kubernetes PPT.pptx
Kubernetes PPT.pptxKubernetes PPT.pptx
Kubernetes PPT.pptx
 
Kubernetes Helm: Why It Matters
Kubernetes Helm: Why It MattersKubernetes Helm: Why It Matters
Kubernetes Helm: Why It Matters
 
Introduction to helm
Introduction to helmIntroduction to helm
Introduction to helm
 
Kubernetes Deployment Strategies
Kubernetes Deployment StrategiesKubernetes Deployment Strategies
Kubernetes Deployment Strategies
 
Kubernetes CI/CD with Helm
Kubernetes CI/CD with HelmKubernetes CI/CD with Helm
Kubernetes CI/CD with Helm
 
Hands-On Introduction to Kubernetes at LISA17
Hands-On Introduction to Kubernetes at LISA17Hands-On Introduction to Kubernetes at LISA17
Hands-On Introduction to Kubernetes at LISA17
 
Helm intro
Helm introHelm intro
Helm intro
 
Kubernetes #1 intro
Kubernetes #1   introKubernetes #1   intro
Kubernetes #1 intro
 
Architecture Overview: Kubernetes with Red Hat Enterprise Linux 7.1
Architecture Overview: Kubernetes with Red Hat Enterprise Linux 7.1Architecture Overview: Kubernetes with Red Hat Enterprise Linux 7.1
Architecture Overview: Kubernetes with Red Hat Enterprise Linux 7.1
 
KubeVirt (Kubernetes and Cloud Native Toronto)
KubeVirt (Kubernetes and Cloud Native Toronto)KubeVirt (Kubernetes and Cloud Native Toronto)
KubeVirt (Kubernetes and Cloud Native Toronto)
 
Docker and kubernetes_introduction
Docker and kubernetes_introductionDocker and kubernetes_introduction
Docker and kubernetes_introduction
 
Intro to Helm for Kubernetes
Intro to Helm for KubernetesIntro to Helm for Kubernetes
Intro to Helm for Kubernetes
 
Getting Started with Kubernetes
Getting Started with Kubernetes Getting Started with Kubernetes
Getting Started with Kubernetes
 
Docker and kubernetes
Docker and kubernetesDocker and kubernetes
Docker and kubernetes
 

Similar to 모두의 쿠버네티스 (Kubernetes for everyone)

Docker & Kubernetes 기초 - 최용호
Docker & Kubernetes 기초 - 최용호Docker & Kubernetes 기초 - 최용호
Docker & Kubernetes 기초 - 최용호용호 최
 
Backend Master | 3.4.5 Deploy - Docker Principal
Backend Master | 3.4.5 Deploy - Docker PrincipalBackend Master | 3.4.5 Deploy - Docker Principal
Backend Master | 3.4.5 Deploy - Docker PrincipalKyunghun Jeon
 
Docker.소개.30 m
Docker.소개.30 mDocker.소개.30 m
Docker.소개.30 mWonchang Song
 
클라우드의 대세 쿠버네티스란 무엇인가?(윤성훈 클라우드 솔루션 아키텍트) - Webinar
클라우드의 대세 쿠버네티스란 무엇인가?(윤성훈 클라우드 솔루션 아키텍트) - Webinar클라우드의 대세 쿠버네티스란 무엇인가?(윤성훈 클라우드 솔루션 아키텍트) - Webinar
클라우드의 대세 쿠버네티스란 무엇인가?(윤성훈 클라우드 솔루션 아키텍트) - WebinarNAVER CLOUD PLATFORMㅣ네이버 클라우드 플랫폼
 
K8s beginner 2_advanced_ep02_201904221130_post
K8s beginner 2_advanced_ep02_201904221130_postK8s beginner 2_advanced_ep02_201904221130_post
K8s beginner 2_advanced_ep02_201904221130_postInho Kang
 
Devfair kubernetes 101
Devfair kubernetes 101Devfair kubernetes 101
Devfair kubernetes 101Daegwon Kim
 
[17.01.19] docker introduction (Korean Version)
[17.01.19] docker introduction (Korean Version)[17.01.19] docker introduction (Korean Version)
[17.01.19] docker introduction (Korean Version)Ildoo Kim
 
[오픈소스컨설팅]쿠버네티스를 활용한 개발환경 구축
[오픈소스컨설팅]쿠버네티스를 활용한 개발환경 구축[오픈소스컨설팅]쿠버네티스를 활용한 개발환경 구축
[오픈소스컨설팅]쿠버네티스를 활용한 개발환경 구축Ji-Woong Choi
 
1. Docker Network (1)
1. Docker Network (1)1. Docker Network (1)
1. Docker Network (1)DEVELOPER.NET
 
[1A6]Docker로 보는 서버 운영의 미래
[1A6]Docker로 보는 서버 운영의 미래[1A6]Docker로 보는 서버 운영의 미래
[1A6]Docker로 보는 서버 운영의 미래NAVER D2
 
01.WEB SYSTEM BASED ON DOCKER
01.WEB SYSTEM BASED ON DOCKER01.WEB SYSTEM BASED ON DOCKER
01.WEB SYSTEM BASED ON DOCKEROpennaru, inc.
 
Spring cloud on kubernetes
Spring cloud on kubernetesSpring cloud on kubernetes
Spring cloud on kubernetesSangSun Park
 
KT 안재석 박사 - 오픈 소스 기반 클라우드 컴퓨팅 솔루션 open stack 이야기 (2011Y05M28D)
KT 안재석 박사 - 오픈 소스 기반 클라우드 컴퓨팅 솔루션 open stack 이야기 (2011Y05M28D)KT 안재석 박사 - 오픈 소스 기반 클라우드 컴퓨팅 솔루션 open stack 이야기 (2011Y05M28D)
KT 안재석 박사 - 오픈 소스 기반 클라우드 컴퓨팅 솔루션 open stack 이야기 (2011Y05M28D)Ubuntu Korea Community
 
[NDC18] 만들고 붓고 부수고 - 〈야생의 땅: 듀랑고〉 서버 관리 배포 이야기
[NDC18] 만들고 붓고 부수고 - 〈야생의 땅: 듀랑고〉 서버 관리 배포 이야기[NDC18] 만들고 붓고 부수고 - 〈야생의 땅: 듀랑고〉 서버 관리 배포 이야기
[NDC18] 만들고 붓고 부수고 - 〈야생의 땅: 듀랑고〉 서버 관리 배포 이야기Chanwoong Kim
 
[NDC17] Kubernetes로 개발서버 간단히 찍어내기
[NDC17] Kubernetes로 개발서버 간단히 찍어내기[NDC17] Kubernetes로 개발서버 간단히 찍어내기
[NDC17] Kubernetes로 개발서버 간단히 찍어내기SeungYong Oh
 
An overview of kubernetes & (very) simple live demo
An overview of kubernetes & (very) simple live demoAn overview of kubernetes & (very) simple live demo
An overview of kubernetes & (very) simple live demoGwan-Taek Lee
 
[OpenInfra Days Korea 2018] K8s workshop: with containers & K8s on OpenStack ...
[OpenInfra Days Korea 2018] K8s workshop: with containers & K8s on OpenStack ...[OpenInfra Days Korea 2018] K8s workshop: with containers & K8s on OpenStack ...
[OpenInfra Days Korea 2018] K8s workshop: with containers & K8s on OpenStack ...OpenStack Korea Community
 

Similar to 모두의 쿠버네티스 (Kubernetes for everyone) (20)

Docker & Kubernetes 기초 - 최용호
Docker & Kubernetes 기초 - 최용호Docker & Kubernetes 기초 - 최용호
Docker & Kubernetes 기초 - 최용호
 
Backend Master | 3.4.5 Deploy - Docker Principal
Backend Master | 3.4.5 Deploy - Docker PrincipalBackend Master | 3.4.5 Deploy - Docker Principal
Backend Master | 3.4.5 Deploy - Docker Principal
 
Docker.소개.30 m
Docker.소개.30 mDocker.소개.30 m
Docker.소개.30 m
 
Docker Container
Docker ContainerDocker Container
Docker Container
 
클라우드의 대세 쿠버네티스란 무엇인가?(윤성훈 클라우드 솔루션 아키텍트) - Webinar
클라우드의 대세 쿠버네티스란 무엇인가?(윤성훈 클라우드 솔루션 아키텍트) - Webinar클라우드의 대세 쿠버네티스란 무엇인가?(윤성훈 클라우드 솔루션 아키텍트) - Webinar
클라우드의 대세 쿠버네티스란 무엇인가?(윤성훈 클라우드 솔루션 아키텍트) - Webinar
 
[9월 런치 세미나] 도커와 쿠버네티스 기술에 스며들다
[9월 런치 세미나] 도커와 쿠버네티스 기술에 스며들다[9월 런치 세미나] 도커와 쿠버네티스 기술에 스며들다
[9월 런치 세미나] 도커와 쿠버네티스 기술에 스며들다
 
K8s beginner 2_advanced_ep02_201904221130_post
K8s beginner 2_advanced_ep02_201904221130_postK8s beginner 2_advanced_ep02_201904221130_post
K8s beginner 2_advanced_ep02_201904221130_post
 
Devfair kubernetes 101
Devfair kubernetes 101Devfair kubernetes 101
Devfair kubernetes 101
 
Docker osc 0508
Docker osc 0508Docker osc 0508
Docker osc 0508
 
[17.01.19] docker introduction (Korean Version)
[17.01.19] docker introduction (Korean Version)[17.01.19] docker introduction (Korean Version)
[17.01.19] docker introduction (Korean Version)
 
[오픈소스컨설팅]쿠버네티스를 활용한 개발환경 구축
[오픈소스컨설팅]쿠버네티스를 활용한 개발환경 구축[오픈소스컨설팅]쿠버네티스를 활용한 개발환경 구축
[오픈소스컨설팅]쿠버네티스를 활용한 개발환경 구축
 
1. Docker Network (1)
1. Docker Network (1)1. Docker Network (1)
1. Docker Network (1)
 
[1A6]Docker로 보는 서버 운영의 미래
[1A6]Docker로 보는 서버 운영의 미래[1A6]Docker로 보는 서버 운영의 미래
[1A6]Docker로 보는 서버 운영의 미래
 
01.WEB SYSTEM BASED ON DOCKER
01.WEB SYSTEM BASED ON DOCKER01.WEB SYSTEM BASED ON DOCKER
01.WEB SYSTEM BASED ON DOCKER
 
Spring cloud on kubernetes
Spring cloud on kubernetesSpring cloud on kubernetes
Spring cloud on kubernetes
 
KT 안재석 박사 - 오픈 소스 기반 클라우드 컴퓨팅 솔루션 open stack 이야기 (2011Y05M28D)
KT 안재석 박사 - 오픈 소스 기반 클라우드 컴퓨팅 솔루션 open stack 이야기 (2011Y05M28D)KT 안재석 박사 - 오픈 소스 기반 클라우드 컴퓨팅 솔루션 open stack 이야기 (2011Y05M28D)
KT 안재석 박사 - 오픈 소스 기반 클라우드 컴퓨팅 솔루션 open stack 이야기 (2011Y05M28D)
 
[NDC18] 만들고 붓고 부수고 - 〈야생의 땅: 듀랑고〉 서버 관리 배포 이야기
[NDC18] 만들고 붓고 부수고 - 〈야생의 땅: 듀랑고〉 서버 관리 배포 이야기[NDC18] 만들고 붓고 부수고 - 〈야생의 땅: 듀랑고〉 서버 관리 배포 이야기
[NDC18] 만들고 붓고 부수고 - 〈야생의 땅: 듀랑고〉 서버 관리 배포 이야기
 
[NDC17] Kubernetes로 개발서버 간단히 찍어내기
[NDC17] Kubernetes로 개발서버 간단히 찍어내기[NDC17] Kubernetes로 개발서버 간단히 찍어내기
[NDC17] Kubernetes로 개발서버 간단히 찍어내기
 
An overview of kubernetes & (very) simple live demo
An overview of kubernetes & (very) simple live demoAn overview of kubernetes & (very) simple live demo
An overview of kubernetes & (very) simple live demo
 
[OpenInfra Days Korea 2018] K8s workshop: with containers & K8s on OpenStack ...
[OpenInfra Days Korea 2018] K8s workshop: with containers & K8s on OpenStack ...[OpenInfra Days Korea 2018] K8s workshop: with containers & K8s on OpenStack ...
[OpenInfra Days Korea 2018] K8s workshop: with containers & K8s on OpenStack ...
 

Recently uploaded

공학 관점에서 바라본 JMP 머신러닝 최적화
공학 관점에서 바라본 JMP 머신러닝 최적화공학 관점에서 바라본 JMP 머신러닝 최적화
공학 관점에서 바라본 JMP 머신러닝 최적화JMP Korea
 
데이터 분석 문제 해결을 위한 나의 JMP 활용법
데이터 분석 문제 해결을 위한 나의 JMP 활용법데이터 분석 문제 해결을 위한 나의 JMP 활용법
데이터 분석 문제 해결을 위한 나의 JMP 활용법JMP Korea
 
실험 설계의 평가 방법: Custom Design을 중심으로 반응인자 최적화 및 Criteria 해석
실험 설계의 평가 방법: Custom Design을 중심으로 반응인자 최적화 및 Criteria 해석실험 설계의 평가 방법: Custom Design을 중심으로 반응인자 최적화 및 Criteria 해석
실험 설계의 평가 방법: Custom Design을 중심으로 반응인자 최적화 및 Criteria 해석JMP Korea
 
JMP 기능의 확장 및 내재화의 핵심 JMP-Python 소개
JMP 기능의 확장 및 내재화의 핵심 JMP-Python 소개JMP 기능의 확장 및 내재화의 핵심 JMP-Python 소개
JMP 기능의 확장 및 내재화의 핵심 JMP-Python 소개JMP Korea
 
(독서광) 인간이 초대한 대형 참사 - 대형 참사가 일어날 때까지 사람들은 무엇을 하고 있었는가?
(독서광) 인간이 초대한 대형 참사 - 대형 참사가 일어날 때까지 사람들은 무엇을 하고 있었는가?(독서광) 인간이 초대한 대형 참사 - 대형 참사가 일어날 때까지 사람들은 무엇을 하고 있었는가?
(독서광) 인간이 초대한 대형 참사 - 대형 참사가 일어날 때까지 사람들은 무엇을 하고 있었는가?Jay Park
 
JMP를 활용한 가속열화 분석 사례
JMP를 활용한 가속열화 분석 사례JMP를 활용한 가속열화 분석 사례
JMP를 활용한 가속열화 분석 사례JMP Korea
 
JMP가 걸어온 여정, 새로운 도약 JMP 18!
JMP가 걸어온 여정, 새로운 도약 JMP 18!JMP가 걸어온 여정, 새로운 도약 JMP 18!
JMP가 걸어온 여정, 새로운 도약 JMP 18!JMP Korea
 
JMP를 활용한 전자/반도체 산업 Yield Enhancement Methodology
JMP를 활용한 전자/반도체 산업 Yield Enhancement MethodologyJMP를 활용한 전자/반도체 산업 Yield Enhancement Methodology
JMP를 활용한 전자/반도체 산업 Yield Enhancement MethodologyJMP Korea
 

Recently uploaded (8)

공학 관점에서 바라본 JMP 머신러닝 최적화
공학 관점에서 바라본 JMP 머신러닝 최적화공학 관점에서 바라본 JMP 머신러닝 최적화
공학 관점에서 바라본 JMP 머신러닝 최적화
 
데이터 분석 문제 해결을 위한 나의 JMP 활용법
데이터 분석 문제 해결을 위한 나의 JMP 활용법데이터 분석 문제 해결을 위한 나의 JMP 활용법
데이터 분석 문제 해결을 위한 나의 JMP 활용법
 
실험 설계의 평가 방법: Custom Design을 중심으로 반응인자 최적화 및 Criteria 해석
실험 설계의 평가 방법: Custom Design을 중심으로 반응인자 최적화 및 Criteria 해석실험 설계의 평가 방법: Custom Design을 중심으로 반응인자 최적화 및 Criteria 해석
실험 설계의 평가 방법: Custom Design을 중심으로 반응인자 최적화 및 Criteria 해석
 
JMP 기능의 확장 및 내재화의 핵심 JMP-Python 소개
JMP 기능의 확장 및 내재화의 핵심 JMP-Python 소개JMP 기능의 확장 및 내재화의 핵심 JMP-Python 소개
JMP 기능의 확장 및 내재화의 핵심 JMP-Python 소개
 
(독서광) 인간이 초대한 대형 참사 - 대형 참사가 일어날 때까지 사람들은 무엇을 하고 있었는가?
(독서광) 인간이 초대한 대형 참사 - 대형 참사가 일어날 때까지 사람들은 무엇을 하고 있었는가?(독서광) 인간이 초대한 대형 참사 - 대형 참사가 일어날 때까지 사람들은 무엇을 하고 있었는가?
(독서광) 인간이 초대한 대형 참사 - 대형 참사가 일어날 때까지 사람들은 무엇을 하고 있었는가?
 
JMP를 활용한 가속열화 분석 사례
JMP를 활용한 가속열화 분석 사례JMP를 활용한 가속열화 분석 사례
JMP를 활용한 가속열화 분석 사례
 
JMP가 걸어온 여정, 새로운 도약 JMP 18!
JMP가 걸어온 여정, 새로운 도약 JMP 18!JMP가 걸어온 여정, 새로운 도약 JMP 18!
JMP가 걸어온 여정, 새로운 도약 JMP 18!
 
JMP를 활용한 전자/반도체 산업 Yield Enhancement Methodology
JMP를 활용한 전자/반도체 산업 Yield Enhancement MethodologyJMP를 활용한 전자/반도체 산업 Yield Enhancement Methodology
JMP를 활용한 전자/반도체 산업 Yield Enhancement Methodology
 

모두의 쿠버네티스 (Kubernetes for everyone)

  • 2. 알아야 할 배경 지식(1) 애플리케이션 실행 환경의 변화 이미지 출처: kubernetes.io
  • 3. 알아야 할 배경 지식(2-1) 컨테이너 기술 ! 프로세스 단위의 격리 환경 ! 호스트 커널을 공유하고 애플리케이션을 실행하기 위한 라이브러리와 파일만 존재 ! VM에 비해 사이즈가 작아 배포가 빠르고, 성능 손실이 거의 없다 ! 다양한 컨테이너 런타임 기술 중 도커(Docker)가 사실상 표준
  • 4. 알아야 할 배경 지식(2-2) 도커 이미지와 컨테이너 ! 도커 이미지 ○ 컨테이너를 실행하기 위해 필요한 모든 파일들을 캡슐화한 패키지 ○ `Dockerfile`을 기반으로 각 단계마다 레이어(Layer)로 구성되며,
 각 레이어는 이전 레이어를 상속한다 ○ 각 레이어는 읽기 전용이며, 컨테이너가 실행되면 마지막에 쓰기 레이어 추가 ! 도커 컨테이너 ○ 1개의 컨테이너에는 1개의 프로세스를 실행하는 것이 원칙 (PID 1) ○ 컨테이너를 종료하면 쓰기 레이어도 사라진다
  • 5. 알아야 할 배경 지식(2-3) Dockerfile # Dockerfile FROM python:slim-buster ENV PYTHONPATH /bar ENV HOME /usr/src/app WORKDIR ${HOME} COPY server.py ${HOME}/server.py CMD ["python", "server.py"] 읽기 전용 레이어 쓰기 가능 레이어 $ docker build -t [저장소 이름]/[이미지 이름]:[태그] .
  • 6. 알아야 할 배경 지식(2-3) 도커 컨테이너로 서비스를 한다는 것은 ! 하나의 도커 이미지 안에 서비스 운영에 필요한 모든 것들이 들어있다 ! 서비스 운영 환경과 개발 환경의 느슨한 결합 ! 쉽고 빠른 배포 ! 시스템 의존성을 쉽게 업그레이드 ! 확장이 쉽다 (스케일 아웃) ! 효율적인 시스템 자원 활용 (CPU limit / Memory limit) ! 가상 머신(vm)보다 나은 성능
  • 7. 알아야 할 배경 지식(3) 컨테이너화된 애플리케이션 관리 문제 아… 또 컨테이너 맛이 갔네 계속 보고 있을 수도 없고… 직접
 재실행 용사님 일어나세요
  • 8. 쿠버네티스란 무엇인가? 쿠버네티스는 컨테이너화된 워크로드와 서비스를 관리하기 위한 이식할 수 있고,
 확장 가능한 오픈소스 플랫폼으로, 선언적 구성과 자동화를 모두 지원한다. 쿠버네티스는 크고 빠르게 성장하는 생태계를 가지고 있다. 출처: kubernetes.io
  • 9. 쿠버네티스란 무엇인가? ! 컨테이너화된 애플리케이션을 실행하고, 관리하는 역할 ! 요구하는 애플리케이션 상태를 나타내는 선언형 정의 ! 애플리케이션의 현재 상태와 요구한 상태를 일치 시켜주는 역할 ! 애플리케이션의 운영자 책임과 클러스터 운영자의 책임 분리
  • 10. 쿠버네티스가 하지 않는 것들 ! Platform as a Service(PaaS)가 아니다 ! 배포, 스케일링, 로드 밸런싱, 로깅, 모니터링 등의 기능을 제공할 수 있지만, 선택적으로 사용한다 ! CI/CD를 위한 플랫폼이 아니다 
 즉, 소스 코드를 배포하지 않으며 애플리케이션을 빌드하지 않는다 ! 머신(서버)의 설정, 유지보수, 자동 복구 시스템을 제공하지 않는다 ! 단순한 오케스트레이션 시스템이 아닌 독립적이고 조합 가능한 제어 프로세 스들로 구성된다
  • 11. 쿠버네티스 클러스터 전체 구성 이미지 출처: kubernetes.io
  • 12. 쿠버네티스 클러스터 - 컨트롤 플레인 ! etcd ○ 쿠버네티스 클러스터의 모든 데이터를 담 고 있는 Key-Value 저장소 ! kube-api-server ○ 쿠버네티스 클러스터의 허브로서 클라이 언트와 etcd에 저장된 데이터 사이의 상 호 작용을 중개 ○ 사용자(운영자), 클러스터 내 구성 요소, 외부 컴포넌트가 서로 통신할 수 있는 HTTP API 제공
  • 13. 쿠버네티스 클러스터 - 컨트롤 플레인 ! kube-scheduler ○ 새로운 POD를 어떤 워커 노드에 실행 시 킬지 선택하는 역할 ! kube-controller-manager ○ API 서버를 통해 클러스터의 다양한 컴포 넌트들의 상태를 감지하고, 원하는 상태로 만드는 역할 ○ 다양한 컨트롤러가 하나로 패키징되어 단 일 프로세스 내에서 실행된다
  • 14. 쿠버네티스 클러스터 - 워커 노드 ! kubelet ○ 모든 워커 노드에서 실행되는 에이전트 ○ 컨테이너를 생성, 삭제하고 상 태를 모니터링, 마스터 노드와 통신을 담당 ! kube-proxy ○ 모든 워커 노드마다 실행되는 네트워크 프록시 ○ 다른 POD 간의 네트워크 통신 과 클러스터 바깥에서 POD로 네트워크 통신을 할 수 있게
  • 15. 쿠버네티스 오브젝트 - POD ! 쿠버네티스에서 가장 작은 기본 실행 단위 ! 1개 이상의 컨테이너로 구성된 컨테이너의 집합 ! POD 안에 모든 컨테이너는 서로 같은 네트워크 와 볼륨을 공유 ! POD는 고유한 가상 IP를 할당 ! POD 내부 컨테이너끼리 localhost로 통신 가능 (서로 다른 포트 사용시)
  • 16. 쿠버네티스 오브젝트 - POD Manifest # example_pod.yaml apiVersion: v1 kind: Pod metadata: labels: app: webserver name: example-app spec: containers: - image: nginx name: example-app $ kubectl create -f example_pod.yaml $ kubectl run example-app --image nginx --restart=Never ※ 매니페스트 작성 없이 바로 만들기
  • 17. 쿠버네티스 오브젝트 - Service ! POD의 고유 IP는 바뀔 수 있다 ! 클러스터 내외부에서 POD로 접근하기 위한 영속적인 방법 ! 여러 POD에 쉽게 접근할 수 있도록 고유한 도메인 이름을 부여 ! 여러 POD에 요청을 분산하는 로드 밸런서 기 능 수행 ! 접근 방식에 따라 ClusterIP, NodePort, LoadBalancer 타입으로 나뉜다 ;
  • 18. 쿠버네티스 오브젝트 - ReplicaSet ! 정해진 개수(replicas) 만큼 동일한 POD 가 항상 실행되도록 관리 ! 워커 노드 장애 등의 이유로 POD를 사용 할 수 없다면 다른 노드에 POD를 다시 생 성 ! 실제 운영 환경에서 ReplicaSet으로 직접 사용하는 경우는 거의 없다
  • 19. 쿠버네티스 오브젝트 - Deployment ! ReplicaSet의 상위 개념이지만 같은 역할 ! 애플리케이션의 업데이트와 배포를 더욱 편하게 하기 위함 ! ReplicaSet의 변경 사항을 저장하는 Revision을 남겨 롤백이 가능 ! 무중단 서비스를 위해 POD의 롤링 업데이 트 가능
  • 20. 쿠버네티스 오브젝트 - Deployment Manifest # example_deployment.yaml apiVersion: apps/v1 kind: Deployment metadata: labels: app: example-app name: example-app spec: replicas: 3 selector: matchLabels: app: webserver template: metadata: labels: app: webserver spec: containers: - image: nginx name: nginx $ kubectl create -f example_deployment.yaml $ kubectl create deployment example-app --image nginx ※ 매니페스트 작성 없이 바로 만들기