the last mile

49
The Last Mile Disclaimer: I’m only using Windows for PowerPoint. Please don’t judge. @StephenMelrose Lead Software Engineer - BSkyB by Ousseynou Cissé ://www.flickr.com/photos/afuelcalledlove/

Upload: stephen-melrose

Post on 08-May-2015

210 views

Category:

Technology


0 download

DESCRIPTION

Everyone's had to endure the "last mile" of developing an application, but what happens if you consider those tasks from day 1? This talk centres around an application we released at Sky Bet earlier this year, the approaches we took, and how we benefited.

TRANSCRIPT

Page 1: The Last Mile

The Last Mile

Disclaimer: I’m only using Windows for PowerPoint. Please don’t judge.

@StephenMelroseLead Software Engineer - BSkyB

Photo by Ousseynou Cisséhttps://www.flickr.com/photos/afuelcalledlove/

Page 2: The Last Mile

Are Recruiting!Developers, DevOps, Scala/Hadoop,

Node.js Super Heroes, Principle Test Engineers,an Engineering Manager, and more!

[email protected] more info, please see/contact:

Page 3: The Last Mile

SPIN Connector

Page 4: The Last Mile

Context

Page 5: The Last Mile
Page 6: The Last Mile
Page 7: The Last Mile
Page 8: The Last Mile
Page 9: The Last Mile

Image source: http://blog.burningman.com/wp-content/uploads/2012/09/blog4.jpg

Page 10: The Last Mile

(a.k.a. SPIN)

Page 11: The Last Mile

Image source: http://www.psdgraphics.com/file/adhesive-plaster.jpg

Page 12: The Last Mile

Image source: http://patriciaknight.files.wordpress.com/2011/08/change-architect-sign1.jpg

Page 13: The Last Mile
Page 14: The Last Mile

Image source: http://3.bp.blogspot.com/-Kdzzg4pimz0/Udk6bE5tDvI/AAAAAAAAFes/MxIGspcwu3M/s1600/photo.JPG

Page 15: The Last Mile
Page 16: The Last Mile

TestingPerformanceExtendibility

Supportability

Page 17: The Last Mile

Logging

Page 18: The Last Mile

Request failed

Connection lost

Failed to perform action

Page 19: The Last Mile
Page 20: The Last Mile

Request failed

Connection lost

Failed to perform action

Page 21: The Last Mile

Request failed

Connection lost

Failed to perform action

Page 22: The Last Mile

Request failed

Connection lost

Failed to perform action

Page 23: The Last Mile

UsefulInformative

Page 24: The Last Mile

Failed to start-up controller for fixture [gC6RFPZ0IW7Zv_vqFR78Aj6_05c]: Failed to get AMQP details from SPIN Connect API: Failed to get stream AMQP details: HTTP request failed: ETIMEDOUT - Request: {"url":"http://<api-domain>/UnifiedDataAPI/stream/IceHockey/gC6RFPZ0IW7Zv_vqFR78Aj6_05c","options":{"headers":{"Accept-Encoding":"gzip","X-Auth-Token":"XXXXXX"},"timeout":30000,"attempt":2,"uri":"http://<api-domain>/UnifiedDataAPI/stream/IceHockey/gC6RFPZ0IW7Zv_vqFR78Aj6_05c"}}

Page 25: The Last Mile

Failed to start-up controller for fixture [gC6RFPZ0IW7Zv_vqFR78Aj6_05c]: Failed to get AMQP details from SPIN Connect API: Failed to get stream AMQP details: HTTP request failed: ETIMEDOUT - Request: {"url":"http://<api-domain>/UnifiedDataAPI/stream/IceHockey/gC6RFPZ0IW7Zv_vqFR78Aj6_05c","options":{"headers":{"Accept-Encoding":"gzip","X-Auth-Token":"XXXXXX"},"timeout":30000,"attempt":2,"uri":"http://<api-domain>/UnifiedDataAPI/stream/IceHockey/gC6RFPZ0IW7Zv_vqFR78Aj6_05c"}}

Page 26: The Last Mile

Failed to start-up controller for fixture [gC6RFPZ0IW7Zv_vqFR78Aj6_05c]: Failed to get AMQP details from SPIN Connect API: Failed to get stream AMQP details: HTTP request failed: ETIMEDOUT - Request: {"url":"http://<api-domain>/UnifiedDataAPI/stream/IceHockey/gC6RFPZ0IW7Zv_vqFR78Aj6_05c","options":{"headers":{"Accept-Encoding":"gzip","X-Auth-Token":"XXXXXX"},"timeout":30000,"attempt":2,"uri":"http://<api-domain>/UnifiedDataAPI/stream/IceHockey/gC6RFPZ0IW7Zv_vqFR78Aj6_05c"}}

Page 27: The Last Mile

Failed to start-up controller for fixture [gC6RFPZ0IW7Zv_vqFR78Aj6_05c]: Failed to get AMQP details from SPIN Connect API: Failed to get stream AMQP details: HTTP request failed: ETIMEDOUT - Request: {"url":"http://<api-domain>/UnifiedDataAPI/stream/IceHockey/gC6RFPZ0IW7Zv_vqFR78Aj6_05c","options":{"headers":{"Accept-Encoding":"gzip","X-Auth-Token":"XXXXXX"},"timeout":30000,"attempt":2,"uri":"http://<api-domain>/UnifiedDataAPI/stream/IceHockey/gC6RFPZ0IW7Zv_vqFR78Aj6_05c"}}

Page 28: The Last Mile

Failed to start-up controller for fixture [gC6RFPZ0IW7Zv_vqFR78Aj6_05c]: Failed to get AMQP details from SPIN Connect API: Failed to get stream AMQP details: HTTP request failed: ETIMEDOUT - Request: {"url":"http://<api-domain>/UnifiedDataAPI/stream/IceHockey/gC6RFPZ0IW7Zv_vqFR78Aj6_05c","options":{"headers":{"Accept-Encoding":"gzip","X-Auth-Token":"XXXXXX"},"timeout":30000,"attempt":2,"uri":"http://<api-domain>/UnifiedDataAPI/stream/IceHockey/gC6RFPZ0IW7Zv_vqFR78Aj6_05c"}}

Page 29: The Last Mile

Log Tail Video

Page 30: The Last Mile

Nothing

Page 31: The Last Mile
Page 32: The Last Mile
Page 33: The Last Mile

The Syslog Protocol (RFC 5424)

DEBUG Verbose and raw debug information. Use in development only.e.g. request/response bodies

INFO 95% of our logging. Stuff we want to monitor, e.g. HTTP request complete, took X seconds, performed Y actions

NOTICE Similar to INFO, but significant events.Also, errors that CAN happen and we HAVE HANDLED

WARN Errors that SHOULDN’T happen, but we HAVE HANDLED

ERROR Errors that SHOULDN’T happen and we CAN’T HANDLE

CRITICAL Fatal errors that cause the application to crash

Page 34: The Last Mile
Page 35: The Last Mile
Page 36: The Last Mile
Page 37: The Last Mile

Graphs

Page 38: The Last Mile

Node.js LogProcessor Graphitestatsd

Page 39: The Last Mile
Page 40: The Last Mile
Page 41: The Last Mile

Monitoring

Page 42: The Last Mile
Page 43: The Last Mile
Page 44: The Last Mile

Load Testing

Page 45: The Last Mile

SPIN’s API OpenBetSPIN Connector

SPIN Recorder

Page 46: The Last Mile

SPIN’s API OpenBetSPIN Connector

Fake SPIN API Our EntireFrontend Stack

Page 47: The Last Mile

Released to Live

Page 48: The Last Mile

Information exposure is paramountKnow what your app is doing

Automate the monitoringMake sure it can do it

Page 49: The Last Mile

Thank youAny questions?

@StephenMelrosehttp://stephenmelrose.co.uk/