84

피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

Embed Size (px)

Citation preview

Page 1: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일
Page 2: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 2

Page 3: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 3

Page 4: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 4

오늘날 우리는

Page 5: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

5

10 million lines of code

Page 6: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

6

10 million lines of code +

Web Application

Server

Page 7: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

7

10 million lines of code

Web Application

Server+ + Container

Page 8: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

8

Page 9: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

9

Cloud Infrastructure

Virtual Machines

Operating Systems

Web Application Servers

WAR - Your applications

Page 10: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

10

Cloud Infrastructure

Virtual Machines

Operating Systems

Web Application Servers

WAR - Your applications

Dependencies

Page 11: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

11

Cloud Infrastructure

Virtual Machines

Operating Systems

Web Application Servers

WAR - Your applications

Class Path Process restart

System library

Kernel Drivers

Base template (Images)

network, etc

Page 12: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 12

그래서 우리는

Page 13: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

13

Micro service codes +

embedded WAS

(fat JAR)+ container

orchestration

Page 14: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

14

Page 15: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

15

Page 16: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

16

Page 17: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

17

Page 18: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

18

Page 19: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

19

java -jar YOUR-APPLICATION.jar

Page 20: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

20

Cloud Infrastructure

Virtual Machines

Operating Systems

Web Application Servers

WAR - Your applications

Class Path Process restart

System library

Kernel Drivers

Base template (Images)

network, etc

Page 21: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

21

Cloud Infrastructure

Virtual Machines

Operating Systems

Web Application Servers

WAR - Your applications

Kernel Drivers

Base template (Images)

network, etc

Page 22: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

22

Cloud Infrastructure

Virtual Machines

Operating SystemsKernel Drivers

Base template (Images)

network, etc

Page 23: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

23

Cloud Infrastructure

Virtual Machines

Operating Systems

} Cloud FoundryPivotal

Page 24: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

24

STAGING

.JAR

Page 25: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

25

Operating Systems (Stemcell)

Env variables

Log aggregation/etc

STAGING

Page 26: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

26

Operating Systems (Stemcell)

Env variables

Log aggregation/etc

STAGING

Containerization

Page 27: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

27

Operating Systems (Stemcell)

Env variables

Log aggregation/etc

Immutable artifact

(Droplet)

Page 28: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

28

Cloud Infrastructure

Operating Systems (Stemcell)

Env variables

Log aggregation/etc

Operating Systems (Stemcell)

Env variables

Log aggregation/etc

Deploy & Orchestration

Page 29: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

Cloud Foundry?

“A platform that runs your application on the cloud.”with containers

Page 30: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 30

Page 31: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 31

BOSHmanifest.yml

CPI

Page 32: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 32

https://network.pivotal.io

Page 33: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 33

Page 34: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 34

Page 35: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 35

Page 36: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 36

Page 37: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 37

Page 38: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 38

AWS RDS for PostgreSQL AWS S3 AWS RDS for MySQL AWS RDS for Aurora AWS RDS for SQL Server AWS DynamoDB AWS RDS for Oracle AWS RDS for MariaDB AWS SQS

Page 39: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 39

Google Cloud Storage Google BigQuery Google PubSub Google CloudSQL Google Machine Learning APIs

Page 40: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 40

Page 41: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 41

Page 42: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 42

Azure Storage Azure Redis Cache Azure DocumentDB Azure Service Bus Azure Event Hubs Azure SQL Database

Page 43: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 43

$ cf create-service aws-dynamodb standard MYDYNAMODB $ cf bind-service MYAPP MYDYNAMODB

$ cf create-service azure-sqldb standard mysqldb $ cf bind-service MYAPP mysqldb

$ cf create-service google-cloudsql d4_standard mycloudsql $ cf bind-service MYAPP mycloudsql

Page 44: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 44

Service discovery

Config Server

MicroService A

MicroService B

Edge Service

MicroService C

MicroService D

Page 45: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 45

마이크로 서비스

Page 46: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 46

ps -ef | awk '{print $2}' | uniq | wc -l

Page 47: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 47

Page 48: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 48

with &Cloud

Data Flow Reactor

Page 49: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 49

https://dzone.com/articles/microservice-architecture-with-spring-cloud-and-do

Page 50: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 50

Page 51: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 51

Page 52: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 52

Page 53: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 53

Page 54: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 54

AWS RDS for PostgreSQL AWS S3 AWS RDS for MySQL AWS RDS for Aurora AWS RDS for SQL Server AWS DynamoDB AWS RDS for Oracle AWS RDS for MariaDB AWS SQS

Azure Storage Azure Redis Cache Azure DocumentDB Azure Service Bus Azure Event Hubs Azure SQL Database

Google Cloud Storage Google BigQuery Google PubSub Google CloudSQL Google Machine Learning APIs

MySQL PostgreSQL RabbitMQ Gemfire RiakCS Single Sign On DataStax

Page 55: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 55

quick DEMO

Page 56: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 56

Page 57: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 57

Page 58: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 58

Spring Cloud Eureka

Page 59: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 59

Spring Cloud Eureka

Boot App Hystrix

Boot App Hystrix

Page 60: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 60

Spring Cloud Eureka

Boot App Hystrix

Boot App Hystrix

register register

Page 61: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 61

Spring Cloud Eureka

Spring Cloud Zuul Proxy

Boot App Hystrix

Boot App Hystrix

register

Page 62: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 62

Spring Cloud Eureka

Spring Cloud Zuul Proxy

Boot App Hystrix

Boot App Hystrix

share share

Page 63: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 63

Spring Cloud Eureka

Spring Cloud Zuul Proxy

Boot App Hystrix

Boot App Hystrix

service traffic

service traffic

Page 64: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 64

Spring Cloud Eureka

Boot App Hystrix

Boot App Hystrix

register

Page 65: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 65

Spring Cloud Eureka

Boot App Hystrix

Boot App Hystrix

register

share

Page 66: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 66

Spring Cloud Eureka

Boot App - B Hystrix

request 1 Boot App

Hystrix

Page 67: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 67

Spring Cloud Eureka

Boot App - B Hystrix

request 2 Boot App

Hystrix

Page 68: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 68

Page 69: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 69

글로벌 Active - Active

Page 70: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 70

http://techblog.netflix.com/2016/03/global-cloud-active-active-and-beyond.html

Page 71: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 71

Page 72: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 72

Data replication Cassandra EVCache Personalization Data Handling Misrouted Traffic Evolving Chaos Kong

Page 73: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 73

Page 74: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 74

Page 75: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 75

Page 76: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 76

Page 77: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 77

Page 78: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 78

http://techblog.netflix.com/2014/11/introducing-dynomite.html

Page 79: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 79

https://github.com/Netflix/hollow

http://hollow.how/

Page 80: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 80

Cassandra (Thrift and CQL) Redis Dynomite with Redis Elasticsearch Elassandra

https://github.com/Netflix/ndbench

Page 81: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 81

http://techblog.netflix.com/2016_09_01_archive.html

Page 82: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 82

Performance improvement from RH5.10 to Ubuntu 14.04

Page 83: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일

© 2015 Pivotal Software, Inc. All rights reserved. 83

Summary• Light weight container structure

•Multi-cloud with Cloud Foundry

•Application level flexibility with Spring Cloud

•Data store options

•Reference how they did it

Page 84: 피보탈 클라우드 파운드리 밋업 - 2017년 2월 24일