Transcript
Page 1: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Marc  Cluet  

http://www.flickr.com/photos/gozalewis/3422530465/  

Page 2: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Who am I?!

Marc  Cluet  (@lynxman)    Catalan  in  London  Head  of  Operations  at  <redacted>  17  years  of  experience  as  a  SysAdmin  Founding  member  of  Juju  and  MAAS  while  at  Canonical  Built  a  DevOps  Engineering  Team  at  Rackspace  Been  DevOps’in  for  the  last  5  years  

Page 3: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Who am I?!

http://www.meetup.com/London-­‐DevOps/  

Page 4: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

What is Autoscaling?!

Page 5: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

What is Autoscaling?!

WASTED! €€€!

Page 6: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

What is Autoscaling?!

Page 7: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

What is Autoscaling?!

The ability to automatically or semi-automatically scale up and down a group of servers based on computing or traffic demand by provisioning new services!

Page 8: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

http://www.flickr.com/photos/fischerfotos/7419253200/  

Page 9: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Traffic Patterns!

Page 10: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Traffic Patterns!

ON & OFF!Analytics!Banks/Tax Agencies!Test environments!

Page 11: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Traffic Patterns!

FAST GROWTH!Events!Business Growth!Slashdot Effect!

Page 12: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Traffic Patterns!

VARIABLE!News & Media!Event Registrations!Rapid fire sales!

Page 13: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Traffic Patterns!

CONSISTENT!HR Application!Accounting/Finance!E-mail!

Page 14: Autoscaling Best Practices - WebPerf Barcelona Oct 2014
Page 15: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Autoscaling Methodologies!

Time Based!Reactive!

Predictive!

Page 16: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Time Based Autoscaling!

Load  Balancer  

Server   Server  

Page 17: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Time Based Autoscaling!

Load  Balancer  

Server   Server  

9:00am!

Page 18: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Time Based Autoscaling!

Load  Balancer  

Server   Server  

Nov 1st!

Page 19: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Time Based Autoscaling!

Load  Balancer  

Server   Server   Server  

Page 20: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Time Based Autoscaling!

GOOD FOR!On & Off!Consistent!

Page 21: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Reactive Autoscaling!

Load  Balancer  

Server  60%  

Server  60%  

Page 22: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Reactive Autoscaling!

Load  Balancer  

Server  80%  

Server  80%  

Page 23: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Reactive Autoscaling!

Load  Balancer  

Server  60%  

Server  60%  

Server  40%  

Page 24: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Reactive Autoscaling!

Load  Balancer  

Server  30%  

Server  30%  

Server  30%  

Page 25: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Reactive Autoscaling!

Load  Balancer  

Server  45%  

Server  45%  

Page 26: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Reactive Autoscaling!

GOOD FOR!Fast Growth!Variable!

Page 27: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Predictive Autoscaling!

Load  Balancer  

Server   Server  

Page 28: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Predictive Autoscaling!

Load  Balancer  

Server   Server  

Forecasted!Traffic!+30%!

Page 29: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Predictive Autoscaling!

Load  Balancer  

Server   Server   Server  

Page 30: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Predictive Autoscaling!

GOOD FOR!Fast Growth!Variable!

Page 31: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Predictive Autoscaling!

Twitter  University    Improving  Resource    Efficiency  with  Apache  Mesos    Christina  Delimitriou  @chris_deli    http://goo.gl/AQmG8n  

Page 32: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

http://www.flickr.com/photos/samuraislice/3309481048/  

Page 33: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Autoscaling Tools!

Page 34: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Autoscaling Tools!

Amazon Cloudformation!Based on Scaling Groups!High/Low Watermark!Scheduled Events!Uses base image + CF!

Page 35: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Autoscaling Tools!

Rackspace Autoscale!Based on Scaling Groups!High/Low Watermark!Scheduled Events!Uses Gold Image!

Page 36: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Autoscaling Tools!

Rightscale Autoscale!Based on Scaling Groups!High/Low Watermark Quorum!Scheduled Events!Uses Rightscale scripts!$$$!

Page 37: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Autoscaling Tools!

Heat!Based on Templates!High/Low Watermark!Scheduled Events!Uses Heat Scripts!DSL Compatible with CF!

Page 38: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Autoscaling Tools!

Scryer!Based on AI!Predictive Fidelity model!Feeds AWS API!

Page 39: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Autoscaling Tools!

Your own!!Collect your metrics!!collectd, diamond, statsd!

Have a good metrics database!!influxDB, whisper, rrd!

Page 40: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Autoscaling Tools!

Your own!!Write your own autoscaling code!!with message queues! :)!!attached to your code!!brain close to the centre of decision!

Page 41: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

http://www.flickr.com/photos/68751915@N05/6355318323/  

Page 42: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Taking the most of it!

Beware of the Kraken!!Autoscaling can be dangerous!Have min-max allocations!

http://www.flickr.com/photos/liquidnight/5992114196/  

Page 43: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Taking the most of it!

Choose the right metrics!Stay with basic metrics!!CPU, mem, I/O disk/net!

Review autoscaling strategy with metrics!

Page 44: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Taking the most of it!

Choose your strategy!Scale up early!Scale down slowly!Don’t apply the same strategy to all apps!

Page 45: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Taking the most of it!

Phasing in and Phasing Out!Have in mind time to availability!Have in mind also decommission time!Golden Images can help speed!

Page 46: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

https://www.flickr.com/photos/trojan_warrior/30419599/  

Page 47: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

The full chain!

Autoscaling  Event  

Provisioning  Config  Mgmt   Deployment  

Service  Discovery   Orchestration  

Page 48: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Provisioning!

cloud-init

Page 49: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Configuration Mgmt!

Page 50: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Deployment!

Page 51: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Orchestration!

1.  Autoscaling!2.  Self Healing!3.  Cost Forecast!4.  Predictive!!

Page 52: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Service Discovery!

Service  Node  A  

Service  Publication  

Service  Node  B  

Service  Node  C  

Page 53: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Service Discovery!

Service  Node  A  

Health  Check  

Discovery  Agent  

Discovery  Agent  

Service  Node  B  

Health  Check  

Service  Publication  

Page 54: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

Service Discovery!

Page 55: Autoscaling Best Practices - WebPerf Barcelona Oct 2014

https://www.flickr.com/photos/mikko_luntiala/12691267935  

https://www.flickr.com/photos/dullhunk/202872717  

@lynxman!

http://slideshare.net/lynxmanuk/!

!