Skip to content

Latest commit

 

History

History
128 lines (96 loc) · 6.47 KB

00_Introduction.md

File metadata and controls

128 lines (96 loc) · 6.47 KB

[ macOS/ARM64 | Linux/AMD64 ]

Introduction

This guide describes how to set up a production-like Kubernetes cluster on a local machine.

The purpose is primarily educational: to understand better how Kubernetes works under the hood, what it is made of and how its components fit together. For this reason we'll be doing everything from scratch, and we'll avoid using any "convenience" tools that hide all the interesting details from us. If you're looking for a quick recipe to have a working cluster as fast as possible, this guide is probably not for you (although you can also take a look at the TLDR version).

Table of Contents generated with DocToc

Chapters

  1. Learning How to Run VMs with QEMU
  2. Preparing Environment for a VM Cluster
  3. Launching the VM Cluster
  4. Bootstrapping Kubernetes Security
  5. Installing Kubernetes Control Plane
  6. Spinning up Worker Nodes
  7. Installing Essential Cluster Services
  8. Simplifying Network Setup with Cilium (optional)
  9. TLDR Version of the Guide (auxiliary)

Credits

This guide is a result of its author's learning process, which was largely facilitated by Kelsey Hightower's Kubernetes the Hard Way. This guide is written in a similar spirit, with some of its parts loosely reusing commands and configurations from the original.

However, compared to the original Kubernetes the Hard Way, this guide:

  • uses a local environment, as opposed to Google Cloud Platform (which is used at least in the first version of KTHW)
  • is lengthier, and contains more "theoretical" knowledge and introductory material for various tools and subjects, including outside of Kubernetes itself
  • describes a more complete deployment, including a storage provisioner and a service load balancer
  • ships with a set of scripts for the "impatient"

Intended audience

This guide is intended for people which have used Kubernetes to some degree, but want to have a more in-depth knowledge of its inner workings. This may be beneficial in several ways:

  • being able to make better, more informed design decisions for systems running on Kubernetes
  • being able to troubleshoot problems with Kubernetes more effectively
  • being able to support your own Kubernetes deployment

Prerequisites

Prior knowledge

  • some working knowledge of Kubernetes, i.e. knowing what a Pod or Service is, having used kubectl to deploy some simple workloads
  • familiarity with fundamental network protocols (IP, ARP, DNS, DHCP, etc.)
  • general familiarity with Linux and shell scripting

Hardware and OS

The variant of the guide was created and tested on was a MacBook Pro M2 Max running macOS Ventura. This means that some of the commands and tools used here are specific to macOS and the Apple Silicon CPU architecture (also known as AArch64 or ARM64).

While this variant of the guide targets Mac/ARM64, the reference scripts have been written to be multi-platform - they also support Ubuntu/AMD64 (or any distribution using apt, systemd, and netplan).

Since we'll run several VMs at once, a decent amount of RAM is recommended. With default settings, the VMs take 20GB of memory in total. This is an amount that should let you comfortably run some workloads. However, it can be significantly reduced to around 8-10GB if necessary. The resulting installation may not be able to support any "real" application running in Kubernetes, but it should be more than enough for a bare-bones, educational deployment.

Software

For completing this guide, you'll need the following packages:

brew install \
  qemu wget curl cdrtools dnsmasq tmux cfssl kubernetes-cli helm

Scope

In order to make this guide complete, we won't focus just on Kubernetes. We'll also look at some foundational stuff within Linux that makes containerization and Kubernetes possible. We'll also spend some time with general-purpose administrative tools useful for installing and maintaining our deployment.

These include:

Apart from Kubernetes core, our deployment will also include the following third party projects:

Deployment overview

We'll create a cluster out of seven Linux virtual machines:

  • three of them will serve as the Kubernetes control plane
  • one VM will simulate a cloud/hardware load balancer for the Kubernetes API
  • the remaining three VMs will serve as worker nodes

The host (macOS) machine will also require some setup:

  • it will run the virtual network between the VMs and provide internet access
  • it will simulate external mass storage (e.g. a disk array) for Kubernetes, using an NFS-exported directory

Next: Learning How to Run VMs with QEMU