Master Kubernetes networking, architecture, authentication, scaling, storage (and more) in excruciating detail.
Join the next public class in your city or from the comfort of your home.
Explore corporate and private training options.
This is a full-time course on learning and mastering Kubernetes.
Things you need to know about the course:
On this course, there'll be:
A typical schedule for a 4 day course is as follows:
Day 1
Lecture + hands-on labs + challenges
Kubernetes doesn't know how to deploy apps written in languages such as Java, Node.js, or .NET. Instead, it only understands and uses Linux containers. But how do these Linux containers work? Are those strictly necessary to master Kubernetes? In this course, you will familiarise yourself with containers and Docker.
Containers vs VMs
Understanding process isolation
Is Docker the only one?
Docker client-server architecture
Running containers
Building Docker images
Mounting volumes
Exposing ports
Managing containers lifecycle
Injecting environment variables
Debugging running containers
Lecture + hands-on labs + challenges
In this course, you will learn how to build, deploy and scale your application in a Kubernetes cluster. You will also learn how to expose your app to the internet and architect apps that are designed to be horizontally scalable.
Managing containers at scale
The battle of container orchestrators
Visualising the data centre as a single VM
The scheduler is the best Tetris player
Kubernetes as an infrastructure as a service provider
What are Pods, Services, and Ingresses?
Creating a local cluster with minikube
Creating a Deployment
Exposing Deployments
What is a Pod?
Scaling applications
Testing resiliency
Lecture + hands-on labs + challenges
Every time you deploy new features in production, you shouldn't stop your app, change the version and start it again. With zero-downtime deployments, no one notices any glitch while you're upgrading your apps. How does that work in Kubernetes? In this course, you will learn how Services work in Kubernetes and how you can roll out changes with zero downtime using rolling updates. You will also learn about Canary Deployments and Blue-green deployments.
Monitoring for uptime
Liveness probe
Readiness probe
Startup probe
Executing zero downtime deployments with rolling updates
Using labels and selectors
Testing features with canary deployments
Releasing features with blue-green deployments
Understanding rollbacks and ReplicaSets
Day 2
Lecture + hands-on labs
Resources in Kubernetes are described as YAML files. If you wish to have the same resources for different environments such as development, preproduction and production, you may be tempted to copy the files three times. Or you could use a templating engine. In this course, you will learn how to do that with Helm, Kustomize or with your programs in any language.
Creating reusable templates
Helm's templating engine
Understanding the Helm architecture
Templating resources with Go and Sprig
Managing releases with Helm
Reverting changes with rollbacks
Depending on other charts
Storing reusable templates in repositories
Structured templating introduction with YQ
Kubernetes specific structured templating with Kustomize
Using Kubernetes SDKs for templating
Lecture + hands-on labs
Can Kubernetes recover from failures? In this course, you will learn the Kubernetes core components by building a cluster from scratch using kubeadm. But the best way to learn something is by breaking it. So you will also break the cluster one node at the time and observe what happens.
Single and multi-node clusters
Examining the control plane
Persisting changes in etcd
Syncing changes with RAFT
Event-based architecture
Understanding the kubelet
Verifying "no single point of failure"
Setting up a multi-master cluster
Investigating multi-master setup in EKS
Exploring multi-master setup in Monzo
Creating a 3 node cluster with kubeadm
Installing an overlay network
Installing an Ingress controller
Exploring the API without kubectl
Taking down the cluster one node at a time
Day 3
Lecture + hands-on labs
How does Kubernetes handle internal traffic between your microservices? How can two apps in the cluster talk to each other? How is Kubernetes assigning IP addresses to Pods and Services? In this course, you will explore how the traffic is routed inside the cluster.
Network challenge with multiple nodes
Network routing recap
Understanding network requirements
Understanding cluster address limits
Assigning IP addresses
The challenge of service discovery
Exploring the Endpoints
Balancing in-cluster traffic
Routing traffic with kube-proxy
Discovering Service types: headless and ClusterIP
Network security for east-west traffic
Network policy targets
Network policy best practices
Lecture + hands-on labs
How to expose application frontends to the internet from a Kubernetes cluster? What's the solution for Layer 4 and Layer 7? In this course, you will learn about more Service types, and the Ingress.
Layer 4 solution to expose a service
The details of using Nodeport
Provision loadbalancers automatically
Helping out the world to save on IPs
HTTP based routing for domains and paths
Routing traffic with Ingress manifests
The battle of Ingress controllers
End-to-end packet journey
Service mesh use-cases
The ins and outs of service meshes
Lecture
Master advanced placements of workloads in your infrastructure. Learn how to schedule machine learning deployments to nodes with GPU or how you can segregate workloads for regions (useful if you need to comply with policies and regulations).
How the Scheduler works in Kubernetes
Filters and predicates
nodeSelector
Node affinity
Pod affinity/anti-affinity
Taints and tolerations
Topology Spread Constraints
Custom schedulers
Day 4
Lecture + hands-on labs
How does Kubernetes store state? Can you host databases in your cluster? Can you extract configurations and share them with different deployments? How do you make sure that your storage layer is replicated and persisted even if a node becomes unavailable? In this course, you will learn how to deploy a database with durable persistence.
Managing configurations
Managing secrets
Using Kubernetes Volumes
Creating Persistent Volumes
Creating Persistent Volume Claims
Provisioning volumes dynamically
Managing stateful applications
Deploying a single database with persistence
Deploying a clustered database with persistence
Lecture + Hans-on labs
After deploying your app to production, the received traffic may change in unpredictable ways. How do you keep your app responsive at all times? You can adapt the number of replicas. But is it feasible to do this manually, or are there better ways? In this course, you will learn how to autoscale an application based on an application-specific custom metric.
Introduction to autoscaling
The Horizontal Pod Autoscaler
The Kubernetes metrics registry
Exposing metrics from your apps
Installing and configuring Prometheus
Understanding custom and external metrics adapters
Tuning the Horizontal Pod Autoscaler
Lecture
Wear your black hat and try to break the cluster. Study mitigation and countermeasure to secure your cluster against malicious attacks.
Attack matrix of threats
Security for Docker apps
Security for Kubernetes clusters
Security for Kubernetes networking
Authentication in Kubernetes
Role-based access control
Plus a few more
During the fourth day, the instructor will ask you to vote for your favourite topics.
You will cover as many modules as possible, starting from the most popular.
In private and corporate training, you can customise the schedule in full.
Date | Location | Course | Duration | Price | |
---|---|---|---|---|---|
3 Feb | San Francisco | Advanced Kubernetes course | 4 days | USD 2798 | Book ⇢ |
10 Feb | Boston | Advanced Kubernetes course | 4 days | USD 2798 | Book ⇢ |
17 Feb | Munich | Advanced Kubernetes course | 4 days | EUR 2400 | Book ⇢ |
24 Feb | Amsterdam | Advanced Kubernetes course | 4 days | EUR 2400 | Book ⇢ |
24 Feb | Singapore | Advanced Kubernetes course | 4 days | SGD 3400 | Book ⇢ |
20 Mar | Online | Kubernetes course | 2 days | USD 1,499.00 | Book ⇢ |
20 Mar | Online | Advanced Kubernetes course | 4 days | USD 2798.00 | Book ⇢ |
5 May | Munich | Advanced Kubernetes course | 4 days | EUR 2400 | Book ⇢ |
8 May | Online | Kubernetes course | 2 days | USD 1,499.00 | Book ⇢ |
8 May | Online | Advanced Kubernetes course | 4 days | USD 2798.00 | Book ⇢ |
12 May | London | Advanced Kubernetes course | 4 days | GBP 2400 | Book ⇢ |
19 May | Amsterdam | Advanced Kubernetes course | 4 days | EUR 2400 | Book ⇢ |
2 Jun | Boston | Advanced Kubernetes course | 4 days | USD 2798 | Book ⇢ |
9 Jun | San Francisco | Advanced Kubernetes course | 4 days | USD 2798 | Book ⇢ |
6 Oct | London | Advanced Kubernetes course | 4 days | GBP 2400 | Book ⇢ |
Design your private session:
We are Kubernetes practitioners with experience in:
We were also selected to speak at KubeCon — the world's largest Kubernetes and Cloud-Native conference. You can watch the tech talks here:
You can chat with us on the Learnk8s' Telegram Group!
Software developers, Data engineers, Architects and DevOps seeking to learn how to use Kubernetes to automate deployment, scaling and management of containerised applications.
You will receive the joining instructions with all the material needed to run the course after you sign up for the course.
The material was authored for Kubernetes 1.30.
We want to make sure you get real value out of this so we only want your money if you are happy with the product! If you aren't satisfied, please send an email to hello@learnk8s.io with a copy of your receipt and I will refund you.
Sure - send an email to hello@learnk8s.io.