Build a Kubernetes production environment on a single host using KVM
What will be built?
Node | Description |
---|---|
kubemaster1 | Kubernetes Master Node |
kuberun1 | Kubernetes runtime |
kuberun2 | Kubernetes runtime |
kuberun3 | Kubernetes runtime |
kuberun4 | Kubernetes runtime |
Requirements
- Linux host operating system. The instructions at the time of writing are for Ubuntu 20.04
- Python 3. This lab will start
- RAM 32GiB
- Disk Space 512GB
Download this repository
$ git clone git@github.com:dexterp/kubelab.git
$ cd kubelab
Install Libvirt
$ sudo apt install libvirt-clients bridge-utils libvirt-daemon \
libvirt-daemon-system qemu qemu-kvmt virt-manager
Start Libvrtd
$ sudo systemctl start libvirtd
Build and start VMs
$ make build
Using virsh to list vms
Once build is complete you can manage the Virtual Machines using virsh.
$ virsh list
Id Name State
-----------------------------
6 kuberun1 running
7 kuberun2 running
8 kuberun3 running
9 kuberun4 running
10 kubemaster1 running
Host resolution using NSS
In order to resolve VM guest hostnames libvirt has a NSS module which will automatically detect and resolve hostnames using client resolver. More information about libvirt NSS can be found at https://libvirt.org/nss.html.
To resolve hostnames, install libvirt NSS .
$ sudo apt install libnss-libvirt
# Edit /etc/nsswitch.conf to relfect the following line
$ cat /etc/nsswitch.conf
hosts: files libvirt_guest dns
...
ssh to a VM guest
The VMs need a minute or more after starting to allow NSS libvirtd time to pick up the nodes. Once they have appeared one can ssh directly to the host using ones username or the root account. The $USER(s) public key is added to both the root account and the $USER account on each VM guest.
SSH to the kubernetes master to test that connectivity is working
$ ssh kubemaster1
[root@kubemaster1 ~]#
Install Kubernetes Using Ansible
The installation of Kubernetes is installed using an ansible playbook. The Ansible playbook is under the directory ansible/
ansible/site.yml
- Ansible site configurationansible/ansible.cfg
- Ansible configuration fileansible/inventory
- Ansible inventoryansible/roles/**
- Ansible roles
Run the following command to install Kubernetes using the Ansible playbook...
make runplaybook
This lab uses make, ansible, libvirt and other tools to manage the lifecycle of VMs in this lab. This section provides some help on these tools.
make help
- Print help informationmake build
- Build packer container runtime imagesmake vmcreate
- Create VMsmake vmstart
- Start VMsmake play
- Run Ansible Playbook to configure kubernetesmake vmremove
- Remove VMsmake getconf
- Get Kubernetes ~/.kube/config file
As the VMs are managed by Libvirtd the virsh
cli can be used to manage the VMs directly.
Some common commands.
virsh list
- List networksvirsh start <domain>
- Start a domain (VM)