PavloLobachov / skaffold-helm-tutorial

Hands on tutorial to learn docker, kubernetes, helm and skaffold. Ideal as a next step in your learning experience after getting some theory

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

skaffold-helm-tutorial

This tutorial gives you hands on docker, kubernetes, helm and skaffold experience. This is done using a very simple application: vue on the frontend and fastapi python on the backend. The only functionality is to get the time!

How to work with this tutorial

You can set up a hetzner cloud environment if you don't want to work on a local machine. You can do this using the pulumi stack here.

As an alternative, you can work locally. Make sure you have a recent linux distribution with docker installed (eg ubuntu 20.04 with the docker.io package). In order to follow this tutorial in a comfortable way, adhere to:

  • At least 8GB of ram (16 will be even more comfortable, especially if you want to run a heavy IDE)
  • At least 40GB of disk space. When disk space is getting low, kubernetes taints your nodes and your pods won't run anymore!
  • Don't use a hard disk, use a SSD or kubernetes will be horribly slow. Preferably a nvme ssd, not a SATA one.

If you decided to work remotely, you probably want to use Visual studio code remote SSH extension

To get started with the tutorial, clone this repository locally:

git clone https://github.com/Kapernikov/skaffold-helm-tutorial

Then, work in this directory skaffold-helm-tutorial for all the rest of the tutorial.

Prerequisites

This tutorial assumes some knowledge beforehand. You will have trouble following if you don't have the following:

  • A basic understanding of docker. (You must have built a docker image and have written a Dockerfile already). There are lots of tutorials on docker.
  • Some knowledge on linux shell (bash) scripting. Linux shell is used everywhere to glue all kind of stuff together. Go here for a tutorial on using the linux terminal, and here for a tutorial on writing shell scripts (however, you won't need all of the advanced stuff mentioned in that tutorial, so a couple of chapters will do fine).

Software requirements

Note: If you work on a remote machine provided by Kapernikov, the software requirements are already ok, so no need to do anything here!

This tutorial assumes the use of linux. You can also use a virtual machine on windows or WSL2 (avoid WSL1, it won't work). For WSL2, you need to take into account some caveats. See specific instructions here.

This tutorial requires docker! So you need to install docker on your linux machine. On ubuntu, it's as simple as

sudo apt install docker.io

This will install the bundled version of docker, which is not totally up to date. If you want to use newer features (like buildx) you need to install docker ce according to the official instructions.

In addition to this, some frequently used tools are also needed:

sudo apt install wget curl vim zip git

The tutorial: table of contents:

About

Hands on tutorial to learn docker, kubernetes, helm and skaffold. Ideal as a next step in your learning experience after getting some theory

License:Apache License 2.0


Languages

Language:TypeScript 29.5%Language:HTML 20.5%Language:Vue 20.1%Language:Python 14.8%Language:JavaScript 14.6%Language:Shell 0.5%