SlideShare a Scribd company logo
A Million Ways
to Crash Your Cluster
CONTAINER CAMP UK
HENNING JACOBS
@try_except_
2018-09-07
Running Kubernetes in Production: A Million Ways to Crash Your Cluster - Container Camp UK
Running Kubernetes in Production: A Million Ways to Crash Your Cluster - Container Camp UK
4
ZALANDO AT A GLANCE
~ 4.5billion EUR
revenue 2017
> 200
million
visits
per
month
> 15.000
employees in
Europe
> 70%
of visits via
mobile devices
> 23
million
active customers
> 300.000
product choices
~ 2.000
brands
15
countries
5
SCALE
95Clusters
378Accounts
INCIDENTS ARE FINE
7
INCIDENT #1: CUSTOMER IMPACT
8
INCIDENT #1: IAM RETURNING 404
9
INCIDENT #1: NUMBER OF PODS
10
LIFE OF A REQUEST (INGRESS)
DNS
my-app.example.org
ALB
aws-1234-lb.eu-central-1.elb.amazonaws.com
SERVICE
10.3.0.216
DEPLOYMENT
POD
10.2.0.1
POD
10.2.1.1
POD
10.2.2.1
POD
10.2.3.1
SKIPPER
172.31.1.1:9999
SKIPPER
172.31.2.1:9999
SKIPPER
172.31.3.1:9999
SKIPPER
172.31.4.1:9999
ALIAS Record
11
INCIDENT #1: INNOCENT MANIFEST
apiVersion: batch/v2alpha1
kind: CronJob
metadata:
name: "foobar"
labels:
application: "foobar"
spec:
schedule: "*/15 9-19 * * Mon-Fri"
jobTemplate:
spec:
template:
metadata:
labels:
application: "foobar"
spec:
restartPolicy: Never
concurrencyPolicy: Forbid
successfulJobsHistoryLimit: 1
failedJobsHistoryLimit: 1
containers:
...
12
INCIDENT #1: FIXED CRON JOB
apiVersion: batch/v2alpha1
kind: CronJob
metadata:
name: "foobar"
labels:
application: "foobar"
spec:
schedule: "7 8-18 * * Mon-Fri"
concurrencyPolicy: Forbid
successfulJobsHistoryLimit: 1
failedJobsHistoryLimit: 1
jobTemplate:
spec:
activeDeadlineSeconds: 120
template:
metadata:
labels:
application: "foobar"
spec:
restartPolicy: Never
containers:
...
13
INCIDENT #1: LESSONS LEARNED
• ALB routes traffic to ALL hosts if all hosts report “unhealthy”
• Fix Skipper Ingress to stay “healthy” during API server problems
• Fix Skipper Ingress to retain last known set of routes
• Use quota for number of pods
apiVersion: v1
kind: ResourceQuota
metadata:
name: compute-resources
spec:
hard:
pods: "1500"
14
INCIDENT #2: CLUSTER DOWN
15
INCIDENT #2: MANUAL OPERATION
% etcdctl del -r /registry-kube-1/certificatesigningrequest prefix
16
INCIDENT #2: RTFM
% etcdctl del -r /registry-kube-1/certificatesigningrequest prefix
help: etcdctl del [options] <key> [range_end]
17
Junior Engineers are Features, not Bugs
https://www.youtube.com/watch?v=cQta4G3ge44
https://www.outcome-eng.com/human-error-never-root-cause/
19
INCIDENT #2: LESSONS LEARNED
• Disaster Recovery Plan?
• Backup etcd to S3
• Monitor the snapshots
20
INCIDENT #3: LATENCY SPIKES
...
Kubernetes worker and master nodes sporadically fail to connect to etcd
causing timeouts in the APIserver and disconnects in the pod network.
...
21
INCIDENT #3: STOP THE BLEEDING
#!/bin/bash
SLEEPTIME=60
while true; do
echo "sleep for $SLEEPTIME seconds"
sleep $SLEEPTIME
timeout 5 curl http://localhost:8080/api/v1/nodes > /dev/null
if [ $? -eq 0 ]; then
echo "all fine, no need to restart etcd member"
continue
else
echo "restarting etcd-member"
systemctl restart etcd-member
fi
done
22
INCIDENT #3: CONFIRMATION FROM AWS
[...]
We can’t go into the details [...] that resulted the networking problems during
the “non-intrusive maintenance”, as it relates to internal workings of EC2.
We can confirm this only affected the T2 instance types, ...
[...]
We don’t explicitly recommend against running production services on T2
[...]
23
INCIDENT #3: LESSONS LEARNED
• It's never the AWS infrastructure until it is
• Treat t2 instances with care
• Kubernetes components are not necessarily "cloud native"
Cloud Native? Declarative, dynamic, resilient, and scalable
24
INCIDENT #4: IMPACT
25
INCIDENT #4: CLUSTER DOWN?
26
INCIDENT #4: THE TRIGGER
https://www.outcome-eng.com/human-error-never-root-cause/
28
CLUSTER UPGRADE
FLOW
29
CLUSTER LIFECYCLE MANAGER (CLM)
github.com/zalando-incubator/cluster-lifecycle-manager
30
CLUSTER CHANNELS
github.com/zalando-incubator/kubernetes-on-aws
Channel Description Clusters
dev Development and playground clusters. 3
alpha Main infrastructure cluster (important to us). 1
beta
Product clusters for the rest of the
organization (prod/test). 90+
31
E2E TESTS ON EVERY PR
github.com/zalando-incubator/kubernetes-on-aws
32
RUNNING E2E TESTS (BEFORE)
Control plane
nodenode
branch: dev
Create Cluster Run e2e tests Delete Cluster
Testing dev to alpha upgrade
Control plane Control plane
33
RUNNING E2E TESTS (NOW)
Control plane
nodenode
Control plane
nodenode
branch: alpha (base) branch: dev (head)
Create Cluster Update Cluster Run e2e tests Delete Cluster
Testing dev to alpha upgrade
Control plane Control plane
34
INCIDENT #4: LESSONS LEARNED
• Automated end-to-end tests are pretty good, but not enough
• Test the diff/migration automatically
• Bootstrap new cluster with the previous configuration
• Apply new configuration
• Run end-to-end & conformance tests
35
INCIDENT #5: IMPACT
[4:59 PM] Marc: There is a error during build - forbidden: image policy webhook backend denied
one or more images: X-Trusted header "false" for image pierone../ci/cdp-builder:234 ..
[5:01 PM] Alice: Now it does not start the build step at all
[5:02 PM] John: +1
[5:02 PM] John: Failed to create builder pod: …
[5:02 PM] Pedro: +1
[5:04 PM] Damien: +1
[5:19 PM] Anton: We're currently having issues pulling images from our Docker registry which
results in many problems…
...
36
INCIDENT #5: IMPACT
37
INCIDENT #5: A VERY INNOCENT PULL REQUEST
38
INCIDENT #5: WHAT HAPPENED
• Deployment caused rebuild with the latest stable Go version
• Library for signature verification was incompatible with Go 1.10,
causing all verification checks to fail during runtime.
• Lack of unit/smoke tests and alerting for one component
• "Near miss": outage could have had large impact
39
A MILLION WAYS TO CRASH YOUR CLUSTER?
• Switch to latest Docker to fix issues with Docker daemon freezing
• Redesign of DNS setup due to high DNS latencies (5s),
switch from kube-dns to node-local dnsmasq+CoreDNS
• Disabling CPU throttling (CFS quota) to avoid latency issues
• Quick fix for timeouts using etcd-proxy: client-go still seems to have
issues with timeouts
• 502's during cluster updates: race condition during network setup
40
MORE TOPICS
• Graceful Pod shutdown and
race conditions (endpoints, Ingress)
• Incompatible Kubernetes changes
• CoreOS ContainerLinux "stable" won't boot
• Kubernetes EBS volume handling
• Docker
41
RACE CONDITIONS..
• Switch to the latest Docker version available to fix the issues with Docker daemon freezing
• Redesign of DNS setup due to high DNS latencies (5s), switch from kube-dns to CoreDNS
• Disabling CPU throttling (CFS quota) to avoid latency issues
• Quick fix for timeouts using etcd-proxy, since client-go still seems to have issues with timeouts
• 502's during cluster updates: race condition
•
github.com/zalando-incubator/kubernetes-on-aws
42
TIMEOUTS TO API SERVER..
github.com/zalando-incubator/kubernetes-on-aws
WELCOME TO
CLOUD NATIVE!
44
45
OPEN SOURCE
Kubernetes on AWS
github.com/zalando-incubator/kubernetes-on-aws
AWS ALB Ingress controller
github.com/zalando-incubator/kube-ingress-aws-controller
Skipper HTTP Router & Ingress controller
github.com/zalando/skipper
External DNS
github.com/kubernetes-incubator/external-dns
Postgres Operator
github.com/zalando-incubator/postgres-operator
Kubernetes Resource Report
github.com/hjacobs/kube-resource-report
Kubernetes Downscaler
github.com/hjacobs/kube-downscaler
46
KUBERNETES RESOURCE REPORT
github.com/hjacobs/kube-resource-report
https://github.com/hjacobs/kube-ops-view
48
OTHER TALKS
• Nordstrom: 101 Ways to Crash Your Cluster - KubeCon 2017
• Monzo: Anatomy of a Production Kubernetes Outage - KubeCon 2018
• Inside Kubernetes Resource Management (QoS) - KubeCon 2018
We need more failure talks!
QUESTIONS?
HENNING JACOBS
HEAD OF
DEVELOPER PRODUCTIVITY
henning@zalando.de
@try_except_
Illustrations by @01k

More Related Content

PDF
Let's talk about Failures with Kubernetes - Hamburg Meetup
PDF
Kubernetes Failure Stories, or: How to Crash Your Cluster - ContainerDays EU ...
PDF
Running Kubernetes in Production: A Million Ways to Crash Your Cluster - DevO...
PDF
Ensuring Kubernetes Cost Efficiency across (many) Clusters - DevOps Gathering...
PDF
Kubernetes Failure Stories - KubeCon Europe Barcelona
PDF
Optimizing Kubernetes Resource Requests/Limits for Cost-Efficiency and Latenc...
PDF
Why I love Kubernetes Failure Stories and you should too - GOTO Berlin
PDF
Optimizing Kubernetes Resource Requests/Limits for Cost-Efficiency and Latency
Let's talk about Failures with Kubernetes - Hamburg Meetup
Kubernetes Failure Stories, or: How to Crash Your Cluster - ContainerDays EU ...
Running Kubernetes in Production: A Million Ways to Crash Your Cluster - DevO...
Ensuring Kubernetes Cost Efficiency across (many) Clusters - DevOps Gathering...
Kubernetes Failure Stories - KubeCon Europe Barcelona
Optimizing Kubernetes Resource Requests/Limits for Cost-Efficiency and Latenc...
Why I love Kubernetes Failure Stories and you should too - GOTO Berlin
Optimizing Kubernetes Resource Requests/Limits for Cost-Efficiency and Latency

What's hot (20)

PDF
Kubernetes + Python = ❤ - Cloud Native Prague
PDF
How Zalando runs Kubernetes clusters at scale on AWS - AWS re:Invent
PDF
Developer Experience at Zalando - CNCF End User SIG-DX
PDF
05.10.2017 AWS User Group Meetup - FALLACIES OF DISTRIBUTED COMPUTING WITH KU...
PDF
Why Kubernetes? Cloud Native and Developer Experience at Zalando - OWL Tech &...
PDF
Kubernetes on AWS at Zalando: Failures & Learnings - DevOps NRW
PDF
Why Kubernetes? Cloud Native and Developer Experience at Zalando - Enterprise...
PDF
Why we don’t use the Term DevOps: the Journey to a Product Mindset - DevOpsCo...
PDF
Kubernetes at Datadog Scale
PDF
DockerCon EU 2015: The Glue is the Hard Part: Making a Production-Ready PaaS
PDF
On-Demand Image Resizing from Part of the monolith to Containerized Microserv...
PDF
Making the most out of kubernetes audit logs
PDF
Securing Your Containerized Applications with NGINX
PDF
Deep dive in container service discovery
PDF
Kernel load-balancing for Docker containers using IPVS
PDF
Kubernetes DNS Horror Stories
PDF
Browser Testing with Docker - Craig Huber
PDF
Minikube Workshop Handout
PDF
Kubernetes: Beyond Baby Steps
PDF
Kubernetes the Very Hard Way. Lisa Portland 2019
Kubernetes + Python = ❤ - Cloud Native Prague
How Zalando runs Kubernetes clusters at scale on AWS - AWS re:Invent
Developer Experience at Zalando - CNCF End User SIG-DX
05.10.2017 AWS User Group Meetup - FALLACIES OF DISTRIBUTED COMPUTING WITH KU...
Why Kubernetes? Cloud Native and Developer Experience at Zalando - OWL Tech &...
Kubernetes on AWS at Zalando: Failures & Learnings - DevOps NRW
Why Kubernetes? Cloud Native and Developer Experience at Zalando - Enterprise...
Why we don’t use the Term DevOps: the Journey to a Product Mindset - DevOpsCo...
Kubernetes at Datadog Scale
DockerCon EU 2015: The Glue is the Hard Part: Making a Production-Ready PaaS
On-Demand Image Resizing from Part of the monolith to Containerized Microserv...
Making the most out of kubernetes audit logs
Securing Your Containerized Applications with NGINX
Deep dive in container service discovery
Kernel load-balancing for Docker containers using IPVS
Kubernetes DNS Horror Stories
Browser Testing with Docker - Craig Huber
Minikube Workshop Handout
Kubernetes: Beyond Baby Steps
Kubernetes the Very Hard Way. Lisa Portland 2019
Ad

Similar to Running Kubernetes in Production: A Million Ways to Crash Your Cluster - Container Camp UK (20)

PDF
Continuously Deliver Your Kubernetes Infrastructure - KubeCon 2018 Copenhagen
PDF
Large Scale Kubernetes on AWS at Europe's Leading Online Fashion Platform - A...
PDF
KubeCon 2019 Recap (Parts 1-3)
PDF
12.07.2017 Docker Meetup - KUBERNETES ON AWS @ ZALANDO TECH
PDF
Large Scale Kubernetes on AWS at Europe's Leading Online Fashion Platform - C...
PDF
Automatic Ingress in Kubernetes
PDF
Kubernetes on AWS @ Zalando Tech
PPTX
Kubernetes at NU.nl (Kubernetes meetup 2019-09-05)
PDF
Successful K8S Platforms in Airgapped Environments
PDF
Kubernetes: Learning from Zero to Production
PPTX
How do we use Kubernetes
PDF
Fallacies of distributed computing with Kubernetes on AWS
PDF
Why we don’t use the Term DevOps: the Journey to a Product Mindset - Destinat...
PDF
Kubecon seattle 2018 workshop slides
PDF
Kubernetes at Zalando - CNCF End User Committee Presentation
PDF
Addressing the 8 Key Pain Points of Kubernetes Cluster Management
PDF
From AWS/STUPS to Kubernetes on AWS @Zalando - Berlin Kubernetes Meetup
PPTX
Container orchestration and microservices world
PPTX
How Zalando integrates Kubernetes with AWS
PPTX
Cloud Native Summit 2019 Summary
Continuously Deliver Your Kubernetes Infrastructure - KubeCon 2018 Copenhagen
Large Scale Kubernetes on AWS at Europe's Leading Online Fashion Platform - A...
KubeCon 2019 Recap (Parts 1-3)
12.07.2017 Docker Meetup - KUBERNETES ON AWS @ ZALANDO TECH
Large Scale Kubernetes on AWS at Europe's Leading Online Fashion Platform - C...
Automatic Ingress in Kubernetes
Kubernetes on AWS @ Zalando Tech
Kubernetes at NU.nl (Kubernetes meetup 2019-09-05)
Successful K8S Platforms in Airgapped Environments
Kubernetes: Learning from Zero to Production
How do we use Kubernetes
Fallacies of distributed computing with Kubernetes on AWS
Why we don’t use the Term DevOps: the Journey to a Product Mindset - Destinat...
Kubecon seattle 2018 workshop slides
Kubernetes at Zalando - CNCF End User Committee Presentation
Addressing the 8 Key Pain Points of Kubernetes Cluster Management
From AWS/STUPS to Kubernetes on AWS @Zalando - Berlin Kubernetes Meetup
Container orchestration and microservices world
How Zalando integrates Kubernetes with AWS
Cloud Native Summit 2019 Summary
Ad

More from Henning Jacobs (12)

PDF
Open Source at Zalando - OSB Open Source Day 2019
PDF
Optimizing Kubernetes Resource Requests/Limits for Cost-Efficiency and Latenc...
PDF
Developer Experience at Zalando - Handelsblatt Strategisches IT-Management 2019
PDF
API First with Connexion - PyConWeb 2018
PDF
Developer Journey at Zalando - Idea to Production with Containers in the Clou...
PDF
Kubernetes on AWS @Zalando - Berlin AWS User Group 2017-05-09
PDF
Kubernetes on AWS at Europe's Leading Online Fashion Platform
PDF
Plan B: Service to Service Authentication with OAuth
PDF
Docker Berlin Meetup Nov 2015: Zalando Intro
PDF
STUPS @ AWS Enterprise Web Day Oktober 2015
PDF
Python at Zalando Technology @ Python Users Berlin Meetup September 2015
PDF
STUPS by Zalando @WHD.local Frankfurt: STUPS.io - an Open Source Cloud Framew...
Open Source at Zalando - OSB Open Source Day 2019
Optimizing Kubernetes Resource Requests/Limits for Cost-Efficiency and Latenc...
Developer Experience at Zalando - Handelsblatt Strategisches IT-Management 2019
API First with Connexion - PyConWeb 2018
Developer Journey at Zalando - Idea to Production with Containers in the Clou...
Kubernetes on AWS @Zalando - Berlin AWS User Group 2017-05-09
Kubernetes on AWS at Europe's Leading Online Fashion Platform
Plan B: Service to Service Authentication with OAuth
Docker Berlin Meetup Nov 2015: Zalando Intro
STUPS @ AWS Enterprise Web Day Oktober 2015
Python at Zalando Technology @ Python Users Berlin Meetup September 2015
STUPS by Zalando @WHD.local Frankfurt: STUPS.io - an Open Source Cloud Framew...

Recently uploaded (20)

PPTX
How to Build Crypto Derivative Exchanges from Scratch.pptx
PPTX
Understanding_Digital_Forensics_Presentation.pptx
PPTX
Web Security: Login Bypass, SQLi, CSRF & XSS.pptx
PDF
Smarter Business Operations Powered by IoT Remote Monitoring
PDF
NewMind AI Weekly Chronicles - August'25 Week I
PDF
Automating ArcGIS Content Discovery with FME: A Real World Use Case
PDF
CIFDAQ's Teaching Thursday: Moving Averages Made Simple
PDF
CIFDAQ's Token Spotlight: SKY - A Forgotten Giant's Comeback?
PDF
HCSP-Presales-Campus Network Planning and Design V1.0 Training Material-Witho...
PDF
REPORT: Heating appliances market in Poland 2024
PDF
Enable Enterprise-Ready Security on IBM i Systems.pdf
PDF
ai-archetype-understanding-the-personality-of-agentic-ai.pdf
PDF
Sensors and Actuators in IoT Systems using pdf
PDF
creating-agentic-ai-solutions-leveraging-aws.pdf
PPTX
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
PPTX
Telecom Fraud Prevention Guide | Hyperlink InfoSystem
PPTX
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
PDF
CIFDAQ's Market Insight: SEC Turns Pro Crypto
PDF
madgavkar20181017ppt McKinsey Presentation.pdf
PDF
How AI Agents Improve Data Accuracy and Consistency in Due Diligence.pdf
How to Build Crypto Derivative Exchanges from Scratch.pptx
Understanding_Digital_Forensics_Presentation.pptx
Web Security: Login Bypass, SQLi, CSRF & XSS.pptx
Smarter Business Operations Powered by IoT Remote Monitoring
NewMind AI Weekly Chronicles - August'25 Week I
Automating ArcGIS Content Discovery with FME: A Real World Use Case
CIFDAQ's Teaching Thursday: Moving Averages Made Simple
CIFDAQ's Token Spotlight: SKY - A Forgotten Giant's Comeback?
HCSP-Presales-Campus Network Planning and Design V1.0 Training Material-Witho...
REPORT: Heating appliances market in Poland 2024
Enable Enterprise-Ready Security on IBM i Systems.pdf
ai-archetype-understanding-the-personality-of-agentic-ai.pdf
Sensors and Actuators in IoT Systems using pdf
creating-agentic-ai-solutions-leveraging-aws.pdf
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
Telecom Fraud Prevention Guide | Hyperlink InfoSystem
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
CIFDAQ's Market Insight: SEC Turns Pro Crypto
madgavkar20181017ppt McKinsey Presentation.pdf
How AI Agents Improve Data Accuracy and Consistency in Due Diligence.pdf

Running Kubernetes in Production: A Million Ways to Crash Your Cluster - Container Camp UK

  • 1. A Million Ways to Crash Your Cluster CONTAINER CAMP UK HENNING JACOBS @try_except_ 2018-09-07
  • 4. 4 ZALANDO AT A GLANCE ~ 4.5billion EUR revenue 2017 > 200 million visits per month > 15.000 employees in Europe > 70% of visits via mobile devices > 23 million active customers > 300.000 product choices ~ 2.000 brands 15 countries
  • 8. 8 INCIDENT #1: IAM RETURNING 404
  • 10. 10 LIFE OF A REQUEST (INGRESS) DNS my-app.example.org ALB aws-1234-lb.eu-central-1.elb.amazonaws.com SERVICE 10.3.0.216 DEPLOYMENT POD 10.2.0.1 POD 10.2.1.1 POD 10.2.2.1 POD 10.2.3.1 SKIPPER 172.31.1.1:9999 SKIPPER 172.31.2.1:9999 SKIPPER 172.31.3.1:9999 SKIPPER 172.31.4.1:9999 ALIAS Record
  • 11. 11 INCIDENT #1: INNOCENT MANIFEST apiVersion: batch/v2alpha1 kind: CronJob metadata: name: "foobar" labels: application: "foobar" spec: schedule: "*/15 9-19 * * Mon-Fri" jobTemplate: spec: template: metadata: labels: application: "foobar" spec: restartPolicy: Never concurrencyPolicy: Forbid successfulJobsHistoryLimit: 1 failedJobsHistoryLimit: 1 containers: ...
  • 12. 12 INCIDENT #1: FIXED CRON JOB apiVersion: batch/v2alpha1 kind: CronJob metadata: name: "foobar" labels: application: "foobar" spec: schedule: "7 8-18 * * Mon-Fri" concurrencyPolicy: Forbid successfulJobsHistoryLimit: 1 failedJobsHistoryLimit: 1 jobTemplate: spec: activeDeadlineSeconds: 120 template: metadata: labels: application: "foobar" spec: restartPolicy: Never containers: ...
  • 13. 13 INCIDENT #1: LESSONS LEARNED • ALB routes traffic to ALL hosts if all hosts report “unhealthy” • Fix Skipper Ingress to stay “healthy” during API server problems • Fix Skipper Ingress to retain last known set of routes • Use quota for number of pods apiVersion: v1 kind: ResourceQuota metadata: name: compute-resources spec: hard: pods: "1500"
  • 15. 15 INCIDENT #2: MANUAL OPERATION % etcdctl del -r /registry-kube-1/certificatesigningrequest prefix
  • 16. 16 INCIDENT #2: RTFM % etcdctl del -r /registry-kube-1/certificatesigningrequest prefix help: etcdctl del [options] <key> [range_end]
  • 17. 17 Junior Engineers are Features, not Bugs https://www.youtube.com/watch?v=cQta4G3ge44
  • 19. 19 INCIDENT #2: LESSONS LEARNED • Disaster Recovery Plan? • Backup etcd to S3 • Monitor the snapshots
  • 20. 20 INCIDENT #3: LATENCY SPIKES ... Kubernetes worker and master nodes sporadically fail to connect to etcd causing timeouts in the APIserver and disconnects in the pod network. ...
  • 21. 21 INCIDENT #3: STOP THE BLEEDING #!/bin/bash SLEEPTIME=60 while true; do echo "sleep for $SLEEPTIME seconds" sleep $SLEEPTIME timeout 5 curl http://localhost:8080/api/v1/nodes > /dev/null if [ $? -eq 0 ]; then echo "all fine, no need to restart etcd member" continue else echo "restarting etcd-member" systemctl restart etcd-member fi done
  • 22. 22 INCIDENT #3: CONFIRMATION FROM AWS [...] We can’t go into the details [...] that resulted the networking problems during the “non-intrusive maintenance”, as it relates to internal workings of EC2. We can confirm this only affected the T2 instance types, ... [...] We don’t explicitly recommend against running production services on T2 [...]
  • 23. 23 INCIDENT #3: LESSONS LEARNED • It's never the AWS infrastructure until it is • Treat t2 instances with care • Kubernetes components are not necessarily "cloud native" Cloud Native? Declarative, dynamic, resilient, and scalable
  • 29. 29 CLUSTER LIFECYCLE MANAGER (CLM) github.com/zalando-incubator/cluster-lifecycle-manager
  • 30. 30 CLUSTER CHANNELS github.com/zalando-incubator/kubernetes-on-aws Channel Description Clusters dev Development and playground clusters. 3 alpha Main infrastructure cluster (important to us). 1 beta Product clusters for the rest of the organization (prod/test). 90+
  • 31. 31 E2E TESTS ON EVERY PR github.com/zalando-incubator/kubernetes-on-aws
  • 32. 32 RUNNING E2E TESTS (BEFORE) Control plane nodenode branch: dev Create Cluster Run e2e tests Delete Cluster Testing dev to alpha upgrade Control plane Control plane
  • 33. 33 RUNNING E2E TESTS (NOW) Control plane nodenode Control plane nodenode branch: alpha (base) branch: dev (head) Create Cluster Update Cluster Run e2e tests Delete Cluster Testing dev to alpha upgrade Control plane Control plane
  • 34. 34 INCIDENT #4: LESSONS LEARNED • Automated end-to-end tests are pretty good, but not enough • Test the diff/migration automatically • Bootstrap new cluster with the previous configuration • Apply new configuration • Run end-to-end & conformance tests
  • 35. 35 INCIDENT #5: IMPACT [4:59 PM] Marc: There is a error during build - forbidden: image policy webhook backend denied one or more images: X-Trusted header "false" for image pierone../ci/cdp-builder:234 .. [5:01 PM] Alice: Now it does not start the build step at all [5:02 PM] John: +1 [5:02 PM] John: Failed to create builder pod: … [5:02 PM] Pedro: +1 [5:04 PM] Damien: +1 [5:19 PM] Anton: We're currently having issues pulling images from our Docker registry which results in many problems… ...
  • 37. 37 INCIDENT #5: A VERY INNOCENT PULL REQUEST
  • 38. 38 INCIDENT #5: WHAT HAPPENED • Deployment caused rebuild with the latest stable Go version • Library for signature verification was incompatible with Go 1.10, causing all verification checks to fail during runtime. • Lack of unit/smoke tests and alerting for one component • "Near miss": outage could have had large impact
  • 39. 39 A MILLION WAYS TO CRASH YOUR CLUSTER? • Switch to latest Docker to fix issues with Docker daemon freezing • Redesign of DNS setup due to high DNS latencies (5s), switch from kube-dns to node-local dnsmasq+CoreDNS • Disabling CPU throttling (CFS quota) to avoid latency issues • Quick fix for timeouts using etcd-proxy: client-go still seems to have issues with timeouts • 502's during cluster updates: race condition during network setup
  • 40. 40 MORE TOPICS • Graceful Pod shutdown and race conditions (endpoints, Ingress) • Incompatible Kubernetes changes • CoreOS ContainerLinux "stable" won't boot • Kubernetes EBS volume handling • Docker
  • 41. 41 RACE CONDITIONS.. • Switch to the latest Docker version available to fix the issues with Docker daemon freezing • Redesign of DNS setup due to high DNS latencies (5s), switch from kube-dns to CoreDNS • Disabling CPU throttling (CFS quota) to avoid latency issues • Quick fix for timeouts using etcd-proxy, since client-go still seems to have issues with timeouts • 502's during cluster updates: race condition • github.com/zalando-incubator/kubernetes-on-aws
  • 42. 42 TIMEOUTS TO API SERVER.. github.com/zalando-incubator/kubernetes-on-aws
  • 44. 44
  • 45. 45 OPEN SOURCE Kubernetes on AWS github.com/zalando-incubator/kubernetes-on-aws AWS ALB Ingress controller github.com/zalando-incubator/kube-ingress-aws-controller Skipper HTTP Router & Ingress controller github.com/zalando/skipper External DNS github.com/kubernetes-incubator/external-dns Postgres Operator github.com/zalando-incubator/postgres-operator Kubernetes Resource Report github.com/hjacobs/kube-resource-report Kubernetes Downscaler github.com/hjacobs/kube-downscaler
  • 48. 48 OTHER TALKS • Nordstrom: 101 Ways to Crash Your Cluster - KubeCon 2017 • Monzo: Anatomy of a Production Kubernetes Outage - KubeCon 2018 • Inside Kubernetes Resource Management (QoS) - KubeCon 2018 We need more failure talks!
  • 49. QUESTIONS? HENNING JACOBS HEAD OF DEVELOPER PRODUCTIVITY [email protected] @try_except_ Illustrations by @01k