building cloud tools for netflix

103
Building Cloud Tools for Netflix @joesondow #netflixcloud Sunday, September 25, 2011

Upload: joe-sondow

Post on 17-May-2015

10.417 views

Category:

Technology


1 download

DESCRIPTION

Using the Amazon cloud requires a lot of moving parts like AMIs, ASGs, and ELBs. See how a small Netflix team developed web-based tools to abstract and clarify these cloudy components for use by hundreds of engineers. Presented at "Talk Cloudy to Me II" hosted by the Silicon Valley Cloud Computing Group in 2011. Apple Keynote version with animations is on Google Docs at http://bit.ly/netflixcloudtools

TRANSCRIPT

Page 1: Building Cloud Tools for Netflix

Building Cloud Tools for Netflix

@joesondow #netflixcloudSunday, September 25, 2011

Page 2: Building Cloud Tools for Netflix

Note takers, take notehttp://www.slideshare.net/joesondow

@joesondow #netflixcloudSunday, September 25, 2011

Page 3: Building Cloud Tools for Netflix

Agenda

@joesondow #netflixcloudSunday, September 25, 2011

Page 4: Building Cloud Tools for Netflix

Agenda

Who am I?

@joesondow #netflixcloudSunday, September 25, 2011

Page 5: Building Cloud Tools for Netflix

Agenda

Who am I?

Why am I here?

@joesondow #netflixcloudSunday, September 25, 2011

Page 6: Building Cloud Tools for Netflix

Agenda

Who am I?

Why am I here?

Cloud deployment model

@joesondow #netflixcloudSunday, September 25, 2011

Page 7: Building Cloud Tools for Netflix

Agenda

Who am I?

Why am I here?

Cloud deployment model

Netflix Application Console

@joesondow #netflixcloudSunday, September 25, 2011

Page 8: Building Cloud Tools for Netflix

Agenda

Who am I?

Why am I here?

Cloud deployment model

Netflix Application Console

Why not the AWS Console?

@joesondow #netflixcloudSunday, September 25, 2011

Page 9: Building Cloud Tools for Netflix

Who am I?

@joesondowSunday, September 25, 2011

Page 10: Building Cloud Tools for Netflix

Who am I?

@joesondowSunday, September 25, 2011

Page 11: Building Cloud Tools for Netflix

Who am I?

Joe Sondow

@joesondowSunday, September 25, 2011

Page 12: Building Cloud Tools for Netflix

Who am I?

Joe Sondow

New York City

@joesondowSunday, September 25, 2011

Page 13: Building Cloud Tools for Netflix

Who am I?

Joe Sondow

New York City

Netflix since 2010

@joesondowSunday, September 25, 2011

Page 14: Building Cloud Tools for Netflix

Who am I?

Joe Sondow

New York City

Netflix since 2010

@joesondowSunday, September 25, 2011

Page 15: Building Cloud Tools for Netflix

Who am I?

Joe Sondow

New York City

Netflix since 2010

Cloud Tools

@joesondowSunday, September 25, 2011

Page 16: Building Cloud Tools for Netflix

Who am I?

Joe Sondow

New York City

Netflix since 2010

Cloud Tools

Grails

@joesondowSunday, September 25, 2011

Page 17: Building Cloud Tools for Netflix

Who am I?

Joe Sondow

New York City

Netflix since 2010

Cloud Tools

Grails

jQuery

@joesondowSunday, September 25, 2011

Page 18: Building Cloud Tools for Netflix

Why am I here?

Sunday, September 25, 2011

Page 19: Building Cloud Tools for Netflix

Why am I here?

Sunday, September 25, 2011

Page 20: Building Cloud Tools for Netflix

Sell you something

Why am I here?

Sunday, September 25, 2011

Page 21: Building Cloud Tools for Netflix

Sell you something

Discuss business plans

Why am I here?

Sunday, September 25, 2011

Page 22: Building Cloud Tools for Netflix

Sell you something

Discuss business plans

Answer technical questions

Why am I here?

Sunday, September 25, 2011

Page 23: Building Cloud Tools for Netflix

Sell you something

Discuss business plans

Answer technical questions

Be a smaller fish in AWS

Why am I here?

Sunday, September 25, 2011

Page 24: Building Cloud Tools for Netflix

Sell you something

Discuss business plans

Answer technical questions

Be a smaller fish in AWS

Steal your engineers

Why am I here?

Sunday, September 25, 2011

Page 25: Building Cloud Tools for Netflix

Cloud deployment model

Sunday, September 25, 2011

Page 26: Building Cloud Tools for Netflix

Cloud deployment modelApplications

Clusters

Sunday, September 25, 2011

Page 27: Building Cloud Tools for Netflix

Cloud deployment model

Sunday, September 25, 2011

Page 28: Building Cloud Tools for Netflix

Cloud deployment model

Auto ScalingGroup

Sunday, September 25, 2011

Page 29: Building Cloud Tools for Netflix

Cloud deployment model

Auto ScalingGroup

LaunchConfiguration

Sunday, September 25, 2011

Page 30: Building Cloud Tools for Netflix

Cloud deployment model

Auto ScalingGroup

LaunchConfiguration

Elastic LoadBalancer

Sunday, September 25, 2011

Page 31: Building Cloud Tools for Netflix

Cloud deployment model

Auto ScalingGroup

LaunchConfiguration

Amazon MachineImage

Elastic LoadBalancer

Sunday, September 25, 2011

Page 32: Building Cloud Tools for Netflix

Cloud deployment model

Auto ScalingGroup

LaunchConfiguration

SecurityGroup

Amazon MachineImage

Elastic LoadBalancer

Sunday, September 25, 2011

Page 33: Building Cloud Tools for Netflix

Cloud deployment model

Auto ScalingGroup

LaunchConfiguration

SecurityGroup

Amazon MachineImage

Instances

Elastic LoadBalancer

Sunday, September 25, 2011

Page 34: Building Cloud Tools for Netflix

Cloud deployment model

Auto ScalingGroup

LaunchConfiguration

SecurityGroup

Amazon MachineImage

Instances

Elastic LoadBalancer

Sunday, September 25, 2011

Page 35: Building Cloud Tools for Netflix

Cloud deployment model

Auto ScalingGroup

LaunchConfiguration

SecurityGroup

Amazon MachineImage

Instances

Elastic LoadBalancer

Sunday, September 25, 2011

Page 36: Building Cloud Tools for Netflix

Cloud deployment model

Auto ScalingGroup

LaunchConfiguration

SecurityGroup

Amazon MachineImage

Instances

Elastic LoadBalancer

Sunday, September 25, 2011

Page 37: Building Cloud Tools for Netflix

Cloud deployment model

Sunday, September 25, 2011

Page 38: Building Cloud Tools for Netflix

Cloud deployment model

Search

Sunday, September 25, 2011

Page 39: Building Cloud Tools for Netflix

Cloud deployment model

API Search

Sunday, September 25, 2011

Page 40: Building Cloud Tools for Netflix

Cloud deployment model

API

Ratings

Search

Sunday, September 25, 2011

Page 41: Building Cloud Tools for Netflix

Cloud deployment modelStreaming Starts

API

Ratings

Search

Sunday, September 25, 2011

Page 42: Building Cloud Tools for Netflix

Cloud deployment modelStreaming Starts

Autocomplete API

Ratings

Search

Sunday, September 25, 2011

Page 43: Building Cloud Tools for Netflix

Cloud deployment modelStreaming Starts

Autocomplete API

Sign Up

Ratings

Search

Sunday, September 25, 2011

Page 44: Building Cloud Tools for Netflix

Cloud deployment modelStreaming Starts

Autocomplete API

Sign Up

Ratings

Search

ApplicationApplication

Application

Application

Application

Application

Sunday, September 25, 2011

Page 45: Building Cloud Tools for Netflix

Inventing the Application

Sunday, September 25, 2011

Page 46: Building Cloud Tools for Netflix

Inventing the Application

Problem:

Application is not an Amazon concept

Sunday, September 25, 2011

Page 47: Building Cloud Tools for Netflix

Inventing the Application

Problem:

Application is not an Amazon concept

Solution:

Create an Application domain in SimpleDB

Enforce naming conventions on Amazon objects

Sunday, September 25, 2011

Page 48: Building Cloud Tools for Netflix

Fast Rollback

Sunday, September 25, 2011

Page 49: Building Cloud Tools for Netflix

Fast Rollback

Optimism causes outages

Sunday, September 25, 2011

Page 50: Building Cloud Tools for Netflix

Fast Rollback

Optimism causes outages

Production traffic is unique

Sunday, September 25, 2011

Page 51: Building Cloud Tools for Netflix

Fast Rollback

Optimism causes outages

Production traffic is unique

Keep old version running

Sunday, September 25, 2011

Page 52: Building Cloud Tools for Netflix

Fast Rollback

Optimism causes outages

Production traffic is unique

Keep old version running

Switch traffic to new version

Sunday, September 25, 2011

Page 53: Building Cloud Tools for Netflix

Fast Rollback

Optimism causes outages

Production traffic is unique

Keep old version running

Switch traffic to new version

Monitor results

Sunday, September 25, 2011

Page 54: Building Cloud Tools for Netflix

Fast Rollback

Optimism causes outages

Production traffic is unique

Keep old version running

Switch traffic to new version

Monitor results

Revert traffic quickly

Sunday, September 25, 2011

Page 55: Building Cloud Tools for Netflix

Fast Rollback

Sunday, September 25, 2011

Page 56: Building Cloud Tools for Netflix

Fast Rollback

api-usprod-v007

api-frontend

Sunday, September 25, 2011

Page 57: Building Cloud Tools for Netflix

Fast Rollback

api-usprod-v007

api-frontend

api-usprod-v008

Sunday, September 25, 2011

Page 58: Building Cloud Tools for Netflix

Fast Rollback

api-usprod-v007

api-frontend

api-usprod-v008

Sunday, September 25, 2011

Page 59: Building Cloud Tools for Netflix

Fast Rollback

api-usprod-v007

api-frontend

api-usprod-v008

Sunday, September 25, 2011

Page 60: Building Cloud Tools for Netflix

Fast Rollback

api-usprod-v007

api-frontend

api-usprod-v008

Sunday, September 25, 2011

Page 61: Building Cloud Tools for Netflix

Fast Rollback

api-frontend

api-usprod-v008

Sunday, September 25, 2011

Page 62: Building Cloud Tools for Netflix

Fast Rollback

Sunday, September 25, 2011

Page 63: Building Cloud Tools for Netflix

Fast Rollback

api-usprod-v007

api-frontend

Sunday, September 25, 2011

Page 64: Building Cloud Tools for Netflix

Fast Rollback

api-usprod-v007

api-frontend

api-usprod-v008

Sunday, September 25, 2011

Page 65: Building Cloud Tools for Netflix

Fast Rollback

api-usprod-v007

api-frontend

api-usprod-v008

Sunday, September 25, 2011

Page 66: Building Cloud Tools for Netflix

Fast Rollback

api-usprod-v007

api-frontend

api-usprod-v008

Sunday, September 25, 2011

Page 67: Building Cloud Tools for Netflix

Fast Rollback

api-usprod-v007

api-frontend

Sunday, September 25, 2011

Page 68: Building Cloud Tools for Netflix

Inventing the Cluster

Sunday, September 25, 2011

Page 69: Building Cloud Tools for Netflix

Inventing the Cluster

Problem:

Two ASGs with one function but different names

Sunday, September 25, 2011

Page 70: Building Cloud Tools for Netflix

Inventing the Cluster

Problem:

Two ASGs with one function but different names

Solution:

Append version number in reserved format

Parse ASG name to determine long-term “cluster”

Sunday, September 25, 2011

Page 71: Building Cloud Tools for Netflix

Netflix Application Console

Sunday, September 25, 2011

Page 72: Building Cloud Tools for Netflix

Netflix Application ConsoleCloud interface

Sunday, September 25, 2011

Page 73: Building Cloud Tools for Netflix

Sunday, September 25, 2011

Page 74: Building Cloud Tools for Netflix

Sunday, September 25, 2011

Page 75: Building Cloud Tools for Netflix

Sunday, September 25, 2011

Page 76: Building Cloud Tools for Netflix

Sunday, September 25, 2011

Page 77: Building Cloud Tools for Netflix

Sunday, September 25, 2011

Page 78: Building Cloud Tools for Netflix

Sunday, September 25, 2011

Page 79: Building Cloud Tools for Netflix

Sunday, September 25, 2011

Page 80: Building Cloud Tools for Netflix

Sunday, September 25, 2011

Page 81: Building Cloud Tools for Netflix

Sunday, September 25, 2011

Page 82: Building Cloud Tools for Netflix

Sunday, September 25, 2011

Page 83: Building Cloud Tools for Netflix

Sunday, September 25, 2011

Page 84: Building Cloud Tools for Netflix

Sunday, September 25, 2011

Page 85: Building Cloud Tools for Netflix

Sunday, September 25, 2011

Page 86: Building Cloud Tools for Netflix

Sunday, September 25, 2011

Page 87: Building Cloud Tools for Netflix

REST API is easy in Grails

Sunday, September 25, 2011

Page 88: Building Cloud Tools for Netflix

REST API is easy in Grails

Sunday, September 25, 2011

Page 89: Building Cloud Tools for Netflix

REST API is easy in Grails

Sunday, September 25, 2011

Page 90: Building Cloud Tools for Netflix

REST API is easy in GrailsApplicationController.groovy

Sunday, September 25, 2011

Page 91: Building Cloud Tools for Netflix

Why not the AWS console?

Sunday, September 25, 2011

Page 92: Building Cloud Tools for Netflix

Why not the AWS console?No, not to keep me busy

Sunday, September 25, 2011

Page 93: Building Cloud Tools for Netflix

Why not the AWS console?

Sunday, September 25, 2011

Page 94: Building Cloud Tools for Netflix

Why not the AWS console?

Sunday, September 25, 2011

Page 95: Building Cloud Tools for Netflix

Why not the AWS console?

Hide keys

Sunday, September 25, 2011

Page 96: Building Cloud Tools for Netflix

Why not the AWS console?

Hide keys

Customize model

Sunday, September 25, 2011

Page 97: Building Cloud Tools for Netflix

Why not the AWS console?

Hide keys

Customize model

Automate workflow

Sunday, September 25, 2011

Page 98: Building Cloud Tools for Netflix

Why not the AWS console?

Hide keys

Customize model

Automate workflow

Enforce conventions

Sunday, September 25, 2011

Page 99: Building Cloud Tools for Netflix

Why not the AWS console?

Hide keys

Customize model

Automate workflow

Enforce conventions

Log changes

Sunday, September 25, 2011

Page 100: Building Cloud Tools for Netflix

Why not the AWS console?

Hide keys

Customize model

Automate workflow

Enforce conventions

Log changes

Integrate systems

Sunday, September 25, 2011

Page 101: Building Cloud Tools for Netflix

Why not the AWS console?

Hide keys

Customize model

Automate workflow

Enforce conventions

Log changes

Integrate systems

Create REST API

Sunday, September 25, 2011

Page 102: Building Cloud Tools for Netflix

Thank you

@joesondowhttp://www.slideshare.net/joesondow

Sunday, September 25, 2011

Page 103: Building Cloud Tools for Netflix

Thank youQuestions?

@joesondowhttp://www.slideshare.net/joesondow

Sunday, September 25, 2011