microservices and full ownership scaling your teams using · 25 consum-er team business team...

61
Scaling your teams using microservices and full ownership Martin Andersen | microcph | May 16, 2017 1

Upload: others

Post on 19-Jun-2020

3 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Scaling your teams using microservices and full ownership

Martin Andersen | microcph | May 16, 2017

1

Page 2: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Me

2

Page 3: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

3

Page 4: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

4

Page 5: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

A bit of history

5

Page 6: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Monolith3w sprints/releases

Test-days

6

Page 7: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

.NET/C#100+ projects

1 repo/solution

7

Page 8: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

8

Page 9: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

WebsWeb/Backend

MainLib/WebExtension

Lib/I18nShared/Foundation

9

Page 10: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

10

DDD

Page 11: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Bounded contexts

11

Page 12: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

API-first

12

Page 13: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

131 server, n services 1 server, 1 service

Page 14: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

14

Organizational Scaling

Page 15: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

2012: 1 team2013: 2 teams

15

Page 16: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

16Ref: https://grasshopperherder.com/lean-startup-in-the-enterprise-anti-pattern-the-lean-waterfall/

Page 17: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

17Ref: https://grasshopperherder.com/lean-startup-in-the-enterprise-anti-pattern-the-lean-waterfall/

Page 18: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

PM TL

UX

ENG

ENG

ENG

Development teamProduct team

UX

PM

Page 19: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

PM

TL UX

ENG

ENG

ENG

Productteam

Page 20: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

PM

TL UX

ENG

ENG

MKT

Cross functionalteam

DSC BA

Page 21: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Full ownership

21

Page 22: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

22

Page 23: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

23

Team A Team B Team C Team D

Context 1

Context 4 Context 6 Context 8

Context 3 Context 5 Context 7

Context 2

Page 24: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

24

Angry Birds

Bad Piggies

Mighty Eagles

Golden Eggs

Context 1

Context 4 Context 6 Context 8

Context 3 Context 5 Context 7

Context 2

Context 7

Context 8

Context 9

Context 10

Context 11

Page 25: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

25

Consum-er Team

Business Team

TrustBox-es

Data Products

Context 1

Context 4 Context 6 Context 8

Context 3 Context 5 Context 7

Context 2

Context 7

Context 8

Context 9

Context 10

Context 11

Growth Team

Context 15

Context 14Context 13Context 12

Context 16

Context 15

Page 26: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

26

Consum-er Team

Business Team

TrustBox-es

Data Products

Context 1

Context 4 Context 6 Context 8

Context 3 Context 5 Context 7

Context 2

Context 7

Context 8

Context 9

Context 10

Context 11

Growth Team

Context 15

Context 14Context 13Context 12

Context 16

Context 15

Page 27: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Open Source model

27

Page 28: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

28

Page 29: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

29

Consum-er Team

Business Team

TrustBox-es

Data Products

Growth Team

Page 30: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

30

Page 31: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

31

Eng. Director

Team TeamTeam

E E E E E E EEE E E

UX Director

Product Director

PM PM PMUX

Page 32: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Technical Scaling

32

Page 33: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

33

Page 34: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

34

API Processing

SQS

Page 35: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

35

Publisher

Subscriber

Subscriber

Subscriber

Subscriber

Subscriber

SNS

Page 36: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Batching

36

Page 37: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Aggregate APIs

37

Page 38: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

38

Client

API

API

API

API

Context

Page 39: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

39

Client

API

API

API

APIAPI

Page 40: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

40

Client

Event

Processing

API

40

API

API

API

API

Page 41: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Learnings

41

Page 42: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

42

Page 43: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Naming things

43

Page 44: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Naming things

44

Page 45: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

45

Page 46: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Communication

46

Page 47: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

47

Page 48: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Automation andProvisioning

48

Page 49: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

49

Page 50: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Shared code ownership

50

Page 51: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Pain-driven development

51

Page 52: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

3rd party services

52

Page 53: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Containerization

53

Page 54: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Serverless

54

Page 55: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Today

55

Page 56: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

10 teams+ Lithuania

56

Page 57: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

57

Page 58: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

58

Page 59: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

59

Page 60: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

~130 deployments / week

60

Page 61: microservices and full ownership Scaling your teams using · 25 Consum-er Team Business Team TrustBox-es Data Products Context 1 Context 4 Context 6 Context 8 Context 3 Context 5

Martin Andersen | Trustpilot | jobs.trustpilot.com61