Go Faster:

Transcription

Go Faster:
Go Faster:
Tech, Process, & Organization
Fred George
fredgeorge@acm.org
@fgeorge52
Copyright © 2015 by Fred George. All rights reserved.
1
Fred George
Consulting Roles
• Change Agent
• Disruptor
• “Hand grenade I am throwing
into development”
• CTO describing Fred to his Vice
President
Copyright © 2015 by Fred George. All rights reserved.
3
Lean startup
Cassandra
MicroServices
Programmer
anarchy
Industry “Hot” Topics
Dev/Ops
Cloud
Full-stack
developer
Docker
Agile
Event bus
MVP (minimum
viable product
Copyright © 2015 by Fred George. All rights reserved.
No-SQL
4
Complex
Complicated
Cause ? Effect
Cause aaa Effect
Chaotic
Simple
Effect? Cause?
Cause a Effect
Why: New Problem Domains:
The CynefinDisorder
Framework
Copyright © 2015 by Fred George. All rights reserved.
5
• Enablement through technologies
• Cloud computing
• Ubiquitous, high bandwidth
• Languages (and supporting frameworks)
Why: Competition is coming
• Recognition of business opportunities
• Silicon Valley innovators as role models
• Accelerating business needs
• Few inhibitors for global competitors
• Reduction of entry barriers for niche competitors
• Micro-marketing to specific customer niches
Copyright © 2015 by Fred George. All rights reserved.
6
How Fast Can You Go?
Copyright © 2015 by Fred George. All rights reserved.
7
SCRUM* *2-3 months
1 mo.
3 wks.
XP
Iteration Length
in Agile Age
XP
2 wks.
XP
1 wk.
XP
1 day
2000
2005
Copyright © 2015 by Fred George. All rights reserved.
2010
2015
8
Project Duration (log)
5 yrs.
Waterfall
1 year
Waterfall
Waterfall
w OO
Agile
Agile
Project Delivery Cycles
1 mon.
1 week
1 day
A2
A2
1980
Copyright © 2015 by Fred George. All rights reserved.
1990
2000
2010
9
How Fast Can You Go?
Deployment to Production Every 3.5 minutes
Copyright © 2015 by Fred George. All rights reserved.
10
Inhibitors
Copyright © 2015 by Fred George. All rights reserved.
11
• Cloud exploitation
• Specialized databases
“Valley
Tech”languages
• New programming
• Open source frameworks (users and creators)
• Continuous releases
Copyright © 2015 by Fred George. All rights reserved.
12
Order lead times (log)
6 mo.
Data Center
1 mo.
1 week
Virtual
Machines
1 day
Hardware
Lead Times
30 min.
5 min.
Commercial
Cloud
Capacity planning?
Dedicated ops team?
Docker
5 sec.
1990
1995
Copyright © 2015 by Fred George. All rights reserved.
2000
2005
2010
2015
13
Number of Services
1000
Netflix
MicroServices
Forward
10
0
SO
A
Services Impact
10
Workshop
Rails / Java Zone
1
1
10
Copyright © 2015 by Fred George. All rights reserved.
100
1000
Size (loc)
10,000
100,000
14
0MQ
0MQ
0MQ
Kafka Bus
Emerging: Event
0MQ
0MQ
0MQ
Service
Copyright © 2015 by Fred George. All rights reserved.
15
Bus
Need
Choose
Sol’n
Need
Sol’n
Sol’n’s
Need
New
Architecture
Patterns
Service
Service
• Variants easy
Service
• Graceful degradation
Copyright © 2015 by Fred George. All rights reserved.
16
CarRent.com
Login
Car
rent
Sally
A
B
Rental
offers
Legacy
server
Incremental Applications
Event Bus
Segmentation
Membership
Copyright © 2015 by Fred George. All rights reserved.
Location
offers
Brand
offers
17
• Fortune 100 view:
• Entity-oriented; consistency essential
• As few as possible
Databases:
• MicroService view:
Holy Grail or Ball-and-Chain?
• Shift to Event Bus, plus
• DB per MicroService (if persistence needed)
• Poly-glot (various NoSQL, SQL) + event buses
• Few (10%) writable; even fewer transactional
Copyright © 2015 by Fred George. All rights reserved.
18
CarRent.com
Login
Car
rent
Sally
A
B
Solution
collecting
Event
Rental
publishing
offers
Legacy
server
Redis
300ms
responder
Segmentation
Membership
Copyright © 2015 by Fred George. All rights reserved.
Location
offers
Brand
offers
19
CarRent.com
Login
Car
rent
Sally
A
ETL
B
Key-value
Rental
offers
Legacy
server
Membership
enrichment
Segmentation
Membership
Copyright © 2015 by Fred George. All rights reserved.
Location
offers
Brand
offers
20
Open Source: Netflix
Copyright © 2015 by Fred George. All rights reserved.
21
Open Source: Docker
Copyright © 2015 by Fred George. All rights reserved.
22
• Middleware exploiting:
• Kafka written in Scala
Disruptive
Technology:
• RabbitMQ written
in Erlang
Functional
Languages
• Case study: MailOnline page rendering
• Legacy system: 130K loc Java/JSP’s
• Replacement: 4,000 loc Clojure
Copyright © 2015 by Fred George. All rights reserved.
23
Mitigate Process Inhibitors
Copyright © 2015 by Fred George. All rights reserved.
24
Understand Your Problem
Complex
Complicated
Cause ? Effect
Cause aaa Effect
Disorder
Chaotic
Simple
Effect? Cause?
Cause a Effect
Copyright © 2015 by Fred George. All rights reserved.
25
New Vision of “What” to Build
Trying ideas
Requirements
Copyright © 2015 by Fred George. All rights reserved.
“Experimentation
drives Innovation”
26
Initiative
Project
Re-think Interactions
Feature
Story
Task
Copyright © 2015 by Fred George. All rights reserved.
Co-Credit: Greg Reiser, ThoughtWorks
27
• Bad metrics:
• Lines of code
• Development stages and milestones met
Measure What Matters
• Business success metrics:
• Sales, clicks, registrations, customer retention, etc.
Copyright © 2015 by Fred George. All rights reserved.
28
Mitigate Organization
Inhibitors
Copyright © 2015 by Fred George. All rights reserved.
29
• Theory:
• Specialist are more productive
•Over-Specialization
Practice:
• Overhead of communication is under-estimated
• Unbalanced workload creates delays
Copyright © 2015 by Fred George. All rights reserved.
30
Case Study:
• 50 IT professionals
Specialization Institutionalized
•with
25+ titles
Titles
• 0 people understanding projects
Copyright © 2015 by Fred George. All rights reserved.
31
Step 1: Define competence in key technologies
Strategic Technologies
•
•
•
•
•
•
•
•
•
•
Ruby
Java
iOS
Android
DB (SQL and non-SQL)
Testing
OO Design
Node.js
HTML/CSS/JavaScript
…
Solution: Fix the Titles
Copyright © 2015 by Fred George. All rights reserved.
32
Expert in 3-5 key
technologies
Competent
in 5-7
key technologies
Expert in a key
technology
New Titles for New Projects
Competent in a key
technology
Not competent in a
key technology
Copyright © 2015 by Fred George. All rights reserved.
33
“Fix the Furniture”*
Copyright © 2015 by Fred George. All rights reserved.
*Kent Beck, XP Explained
34
Non-dedicated Leadership
Copyright © 2015 by Fred George. All rights reserved.
35
Bring Work to the Team…
Not musical
chairs for each
small project
Copyright © 2015 by Fred George. All rights reserved.
36
Reinforcing Movements
Lean startup
Cassandra
MicroServices
Programmer
anarchy
Docker
Dev/Ops
Cloud
Full-stack
developer
Agile
Event bus
MVP (minimum
viable product
Copyright © 2015 by Fred George. All rights reserved.
No-SQL
39
Project Duration (log)
Project Delivery Cycles
5 yrs.
Waterfall
1 year
Waterfall
Waterfall
w OO
Agile
Agile
1 mon.
NRK
1 week
1 day
NRK
1980
Copyright © 2015 by Fred George. All rights reserved.
1990
2000
2010
40
• Neil Hutchinson – Founder of Forward
• Adopting a “Fail Fast” culture
•Acknowledgements
Carl Gaywood
• Former programmer who wanted to Go Faster
• Paul Ingles and Mike Jones
• Implementers of “Experimentation drives innovation”
Copyright © 2015 by Fred George. All rights reserved.
41
• Google:
More Information…
• MicroService Architecture for videos
• MicroXchg 2015 conference
• Programmer Anarchy for managerless teams
• Docker for latest container deployment
Copyright © 2015 by Fred George. All rights reserved.
42
Go Faster:
Tech, Process, & Organization
Fred George
fredgeorge@acm.org
@fgeorge52
Copyright © 2015 by Fred George. All rights reserved.
43