Next Session: This course is paused until further notice.

About the course

The course is hands on. From the first session onwards you will be working with kubernetes, typing the commands and exploring the most important aspects of cluster management.

By the end of the course, you will be able to deploy any web application to a kubernetes cluster. You will also be able to speak on best practices for naming, labeling, namespacing and other hygiene aspects of kubernetes clusters.

Topics Covered

  1. Before Kubernetes
  2. Docker Primer
  3. Kubernetes Architecture
  4. A Kubernetes Cluster on your laptop – Minikube, Kind
  5. Deploy a web application to a Kube cluster
    1. Pods
    2. Replicasets
    3. Deployments
  6. Resource Management and Debugging commands
  7. Kubectl commands
  8. Namespace and labels

About the Instructor

For the past 3 years I have been working on systems built on Kubernetes. While it has its own pain points, the savings over standalone VMs and its flexibility to scale make it ideal for mid-size startups. For smaller startups the problem would be maintenance as it has a bit of a learning curve.

I moved all web-apps in my first team in gojek completely to kubernetes, saving almost 30% of infrastructure costs. Gojek is now working to do this for all application services for all product groups.

I later worked as the Tech Lead for Thailand and Viertnam teams in Gojek. These countries have complete replicas of the gojek core system, running in huge kubernetes clusters. Thats 230 odd services in a single cluster with database and other stateful components in separate clusters. It was managed by a team of only 10 engineers!

This course is my way of giving back to the community by sharing what we learned so that more people can gain the benefits of Kubernetes.

Pre-requisites

  1. Laptop with ubuntu or MacOS (we could try with a windows laptop but it will be trial and error).
  2. Be able to write a simple web server in any one language. If you can do it by googling, thats fine as well.
  3. Docker should be installed
  4. Minikube should be installed
  5. Kind should be installed
  6. Install Golang with version greater than 1.11