29
Spo$fy services

Spotify services - Leetspeak 2014

Embed Size (px)

DESCRIPTION

Slide deck from my presentation at Leetspeak 2014 on how Spotify builds backend services.

Citation preview

Page 1: Spotify services - Leetspeak 2014

Spo$fy'services

Page 2: Spotify services - Leetspeak 2014

ngn@spo'fy.com-@protocol7

Page 3: Spotify services - Leetspeak 2014

Microservices1*in*anger

1"h$p://mar+nfowler.com/ar+cles/microservices.html

Page 4: Spotify services - Leetspeak 2014

Why?

Page 5: Spotify services - Leetspeak 2014

Monoliths

Page 6: Spotify services - Leetspeak 2014

Simplicity

Robustness

Page 7: Spotify services - Leetspeak 2014

Scalability

Page 8: Spotify services - Leetspeak 2014

UNIX%philosophy

"Rule&of&Modularity:&Developers&should&build&a&program&out&of&simple&parts&connected&by&well&defined&interfaces,&so&problems&are&local,&and&parts&of&the&program&can&be&replaced&in&future&versions&to&support&new&features.&This&rule&aims&to&save&@me&on&debugging&

complex&code&that&is&complex,&long,&and&unreadable"

—"Eric"S."Raymond,"The"Art"of"Unix"Programming

Page 9: Spotify services - Leetspeak 2014

Embrace(Conway's(law2

2"h$ps://labs.spo.fy.com/2014/03/27/spo.fy8engineering8culture8part81/

Page 10: Spotify services - Leetspeak 2014

What's'a'service?

Page 11: Spotify services - Leetspeak 2014

Let's&walk&a&request

Page 12: Spotify services - Leetspeak 2014

Perimeter'services

Page 13: Spotify services - Leetspeak 2014
Page 14: Spotify services - Leetspeak 2014

View%services

Page 15: Spotify services - Leetspeak 2014

Service'discovery

Page 16: Spotify services - Leetspeak 2014

$ dig _spotify-search._hm.lon3.spotify.net SRV +short5000 5000 8181 lon3-search-a1.lon3.spotify.net.5000 5000 8181 lon3-search-a2.lon3.spotify.net....

Page 17: Spotify services - Leetspeak 2014

Data$services

Page 18: Spotify services - Leetspeak 2014

Orchestra)on

Page 19: Spotify services - Leetspeak 2014

Scaling(out

Page 20: Spotify services - Leetspeak 2014

Geographical,distribu2on3

3"h$ps://www.youtube.com/watch?v=JEpsKnWZrJ8

Page 21: Spotify services - Leetspeak 2014

Mul$site

Page 22: Spotify services - Leetspeak 2014

Failure(modes

Page 23: Spotify services - Leetspeak 2014

Failure(modesCascading)failures

Page 24: Spotify services - Leetspeak 2014

Failure(modesBuild&for&failure

Page 25: Spotify services - Leetspeak 2014

Failure(modesDrop%requests

Page 26: Spotify services - Leetspeak 2014

Infrastructure+automa.on

Page 27: Spotify services - Leetspeak 2014

Monitoring

Page 28: Spotify services - Leetspeak 2014

Outro

Page 29: Spotify services - Leetspeak 2014

Ques%onsngn@spo'fy.com-@protocol7