63
Production Microservices Chaos from Order

Production Microservices - JAX London · 2018-06-20 · @russmiles @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

  • Upload
    others

  • View
    2

  • Download
    0

Embed Size (px)

Citation preview

Page 1: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Production Microservices

Chaos from Order

Page 2: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z
Page 3: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

A subtitle…

Page 4: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Production …

Page 5: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Hates YOU

Page 6: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Essential Instabilitythrough Change

Page 7: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

What do we aim for?

Page 8: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Fragility?

Page 9: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Robust/Resilient?

Page 10: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Antifragile

Page 11: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Antifragile Systems

Page 12: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

What is the core challenge?

Page 13: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Availability

Page 14: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Aggregate Availability

Page 15: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Time-Based Availability

Page 16: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

What’s your risk tolerance?

Page 17: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Consider…

Page 18: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Target Availability Failure Types

Cost

Page 19: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Stressors-First

Page 20: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

From Stressors to Objectives

Page 21: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

From Objectives to Indicators

Page 22: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

From Indicators to Agreements

Page 23: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Types of Failure to Consider

Page 24: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Infra

Page 25: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Hardware

Infra

Page 26: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Latency

Infra

Page 27: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Network Loss

Infra

Page 28: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Resource Exhaustion

Infra

Page 29: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Inter-Service Comms

Infra

Page 30: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Platform

Page 31: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

State Transmission

Platform

Page 32: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Race Conditions

Platform

Page 33: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Application

Page 34: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Functional

Application

Page 35: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Dependencies Malfunction

Application

Page 36: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

People!

Page 37: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Configuration

Application

Page 38: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

PEBKAC

People

Page 39: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Black Swans

Page 40: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Observability

Page 41: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Indicators

Page 42: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Actionable Information

Page 43: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

How to get this??

Page 44: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

How to get people to care about this?

Page 45: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Game Days

Page 46: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

From Game Days to Chaos

Page 47: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Why Chaos?

Page 48: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Cynefin

Page 49: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

We don’t know… … what we don’t know

Page 50: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

First Rule of Chaos…

Page 51: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Not just about pain

Page 52: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

No surprises

Page 53: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Starts with a Hypothesis

Page 54: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

What do you want to Learn?

Page 55: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

To Probes

Page 56: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

To Actions

Page 57: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Engage with all parties

Page 58: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Build Experiments…

Page 59: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Or thing to try…

Page 60: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Manual and Automated

Page 61: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Automated!

Page 62: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

Repeat is Crucial

Page 63: Production Microservices - JAX London · 2018-06-20 · @russmiles   @chaostoolkit. Title: ChaosToolkitTemplate Created Date: 20171009155508Z

@russmiles

http://chaostoolkit.org https://join.chaostoolkit.org

@chaostoolkit