So You Want To Rewrite That Lessons from a successful - - PowerPoint PPT Presentation
So You Want To Rewrite That Lessons from a successful - - PowerPoint PPT Presentation
So You Want To Rewrite That Lessons from a successful rearchitec8ng Camille Fournier @skamille GOTO Chicago 2014 We were failing to support our
SLIDE 1
SLIDE 2
We ¡were ¡failing ¡to ¡support ¡our ¡ growth, ¡our ¡customers, ¡and ¡our ¡ technology ¡
SLIDE 3
Everything’s not fine.
SLIDE 4
A ¡rewrite ¡will ¡solve ¡all ¡my ¡problems! ¡
SLIDE 5
There’s ¡no ¡such ¡thing ¡as ¡a ¡ successful ¡rewrite ¡ ¡
The ¡sustainable ¡rewrite ¡looks ¡like ¡firefigh8ng ¡
Cliff ¡Moon, ¡Boundary ¡
¡
SLIDE 6
THE ¡PATH ¡TO ¡REWRITING ¡IS ¡ FRAUGHT ¡WITH ¡DANGER ¡
SLIDE 7
You’re ¡failing ¡now. ¡
SLIDE 8
You ¡can’t ¡scale. ¡
SLIDE 9
You ¡can’t ¡meet ¡customer ¡demand. ¡
SLIDE 10
You’re ¡crushed ¡ under ¡the ¡ weight ¡of ¡your ¡ technical ¡debt. ¡
SLIDE 11
It ¡is ¡easy ¡to ¡fail ¡on ¡the ¡unknown ¡ unknowns ¡
SLIDE 12
This ¡doesn’t ¡look ¡THAT ¡big… ¡
How ¡well ¡do ¡you ¡know ¡what ¡the ¡code ¡is ¡doing ¡now? ¡
SLIDE 13
What ¡about ¡the ¡data? ¡
SLIDE 14
How ¡does ¡the ¡team ¡need ¡to ¡change ¡to ¡ make ¡this ¡successful? ¡
SLIDE 15
The ¡sirens ¡will ¡tempt ¡you ¡off ¡
- course. ¡
SLIDE 16
SLIDE 17
Coun8ng ¡on ¡a ¡ “big ¡bang” ¡
- release. ¡
SLIDE 18
Choosing ¡the ¡wrong ¡soWware. ¡
SLIDE 19
Choosing ¡the ¡wrong ¡soWware. ¡
SLIDE 20
WHAT ¡ARE ¡THE ¡PRINCIPLES ¡TO ¡ MAKE ¡THIS ¡SUCCESSFUL? ¡
SLIDE 21
Change ¡as ¡liXle ¡as ¡possible. ¡
SLIDE 22
SLIDE 23
Rewrite ¡but ¡keep ¡the ¡language ¡the ¡
- same. ¡
SLIDE 24
Change ¡only ¡one ¡thing ¡at ¡once ¡(salami ¡ slicing) ¡
SLIDE 25
You ¡need ¡to ¡sell ¡this. ¡
SLIDE 26
Sell ¡it ¡to ¡yourself ¡first. ¡
SLIDE 27
Sell ¡it ¡to ¡the ¡business ¡with ¡Big ¡Scary ¡
- Graphs. ¡
SLIDE 28
Sell ¡it ¡to ¡your ¡team. ¡
SLIDE 29
You ¡need ¡a ¡detailed ¡defini8on ¡of ¡
- done. ¡
SLIDE 30
A ¡test ¡ suite ¡that ¡ acts ¡as ¡a ¡ safety ¡
- harness. ¡
SLIDE 31
What ¡is ¡the ¡quality ¡we’re ¡measuring ¡to ¡ improve? ¡
SLIDE 32
What ¡is ¡our ¡data ¡migra8on ¡plan? ¡
SLIDE 33
WHAT ¡DOES ¡THE ¡OUTCOME ¡LOOK ¡ LIKE? ¡
SLIDE 34
Your ¡culture ¡will ¡change ¡in ¡the ¡
- process. ¡
SLIDE 35
Long-‑8me ¡employees ¡may ¡feel ¡
- threatened. ¡
SLIDE 36
Workflows ¡will ¡have ¡to ¡change. ¡
SLIDE 37
The ¡structure ¡of ¡your ¡team ¡changes. ¡
CTO ¡ Dev ¡ Dev ¡ Dev ¡ Dev ¡ Dev ¡ Dev ¡ Architect ¡
SLIDE 38
The ¡structure ¡of ¡your ¡team ¡changes. ¡
CTO ¡ Director ¡ FrontEnd ¡ Dev ¡ Dev ¡ QA ¡ BackEnd ¡ Dev ¡ Dev ¡ Director ¡ Frontend ¡ QA ¡ Backend ¡ VP ¡Ops ¡ DevOps ¡ DevOps ¡ DevOps ¡ Syseng ¡
SLIDE 39
A ¡new ¡architecture ¡brings ¡new ¡
- challenges. ¡
SLIDE 40
Temp8ng ¡to ¡make ¡v2 ¡everything ¡you ¡ ever ¡wanted! ¡
SLIDE 41
Overengineering ¡can ¡happen ¡to ¡ process, ¡too. ¡
SLIDE 42
User ¡ Checkout ¡ Sta8c ¡Asset ¡CDN ¡Origin ¡ Drupal ¡ Our ¡Runway ¡ Home ¡ Grid ¡ Product ¡Detail ¡ sta8c ¡assets ¡ sinatra ¡views ¡/ ¡erbs ¡ < ¡Sinatra::Base ¡ RtR ¡API ¡clients ¡ Heroku ¡ Rackspace ¡ Engine ¡Yard ¡
SLIDE 43
You’re ¡never ¡really ¡done. ¡
SLIDE 44
You ¡create ¡a ¡system ¡that ¡will ¡last ¡ longer ¡than ¡its ¡predecessor. ¡
SLIDE 45
You ¡have ¡the ¡flexibility ¡to ¡build ¡the ¡ things ¡you ¡will ¡need. ¡
SLIDE 46
You ¡have ¡standards ¡around ¡that ¡ flexibility ¡to ¡mi8gate ¡complexity. ¡
SLIDE 47
Build ¡with ¡the ¡needs ¡of ¡a ¡larger ¡or ¡ smaller ¡team ¡in ¡mind. ¡
SLIDE 48
Everything ¡isn’t ¡fine. ¡
SLIDE 49
It’s ¡8me ¡to ¡rewrite. ¡
SLIDE 50
Sell ¡it, ¡change ¡as ¡liXle ¡as ¡possible, ¡ and ¡know ¡what ¡done ¡looks ¡like. ¡
SLIDE 51
Prepare ¡for ¡a ¡brave ¡new ¡world. ¡
SLIDE 52
Create ¡a ¡sustainable ¡future. ¡
SLIDE 53
Thanks! ¡
- @skamille ¡
- Rent ¡the ¡Runway ¡is ¡hiring! ¡
renXherunway.com/careers ¡
- My ¡blog: ¡whilefalse.blogspot.com ¡
SLIDE 54
credits ¡
- www.mccord-‑museum.qc.ca/fr/collec8on/artefacts/MP-‑0000.2265 ¡
- Zombie ¡mob: ¡hXps://www.flickr.com/photos/aheram/219515706/ ¡
- ¡Fail ¡whale: ¡Rob ¡Friedman ¡/ ¡playerx ¡/ ¡@px ¡
- Na8onal ¡Ocean ¡Service ¡Image ¡Gallery ¡
- hXps://www.flickr.com/photos/maX_gibson/3281131319 ¡
- hXps://www.flickr.com/photos/philliecasablanca/3344142642 ¡
- hXps://www.flickr.com/photos/johnragai/12601518074 ¡
- hXps://www.flickr.com/photos/thomashawk/2369472195 ¡
- hXps://www.flickr.com/photos/richigrafik/4912808572 ¡
- hXps://www.flickr.com/photos/ka8ew/311380970 ¡
- hXps://www.flickr.com/photos/lucianvenu8an/1279760885 ¡
- hXps://www.flickr.com/photos/kaptainkobold/390454090 ¡
- hXps://www.flickr.com/photos/nihonbunka/3353532166 ¡