https://github.com/jamonation/terraform-libvirt-k8s-lab
A project to build nodes for a Kubernetes cluster using Terraform and the libvirt provider, and set up and configure Kubernetes on them using Ansible
https://github.com/jamonation/terraform-libvirt-k8s-lab
ansible hacktoberfest kubernetes kubernetes-labs lab terraform terraform-libvirt-provider
Last synced: 7 months ago
JSON representation
A project to build nodes for a Kubernetes cluster using Terraform and the libvirt provider, and set up and configure Kubernetes on them using Ansible
- Host: GitHub
- URL: https://github.com/jamonation/terraform-libvirt-k8s-lab
- Owner: jamonation
- Created: 2020-10-28T01:19:59.000Z (almost 5 years ago)
- Default Branch: main
- Last Pushed: 2022-12-09T02:56:24.000Z (almost 3 years ago)
- Last Synced: 2025-03-23T22:25:29.914Z (7 months ago)
- Topics: ansible, hacktoberfest, kubernetes, kubernetes-labs, lab, terraform, terraform-libvirt-provider
- Language: HCL
- Homepage:
- Size: 84 KB
- Stars: 15
- Watchers: 2
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Terraform + libvirt + Ansible = HA Kubernetes Lab

## Introduction
A home lab is a great way to explore and learn about different tools, architectures, and development methods.
The idea behind this repository is to use Terraform and Ansible to build a local Kubernetes cluster that is more extensible, and closer to a production architecture than many of the typical single-machine example environments.
## About
This repository contains all the Terraform modules and Ansible roles that you need to build a local [High Availability Kubernetes cluster](https://kubernetes.io/docs/setup/production-environment/tools/kubeadm/ha-topology/) that you can experiment with.
The Terraform modules use the [`libvirt` terraform provider](https://github.com/dmacvicar/terraform-provider-libvirt) to provision a virtual network and virtual machines, so you'll need to be running `libvirtd` on Linux to be able to use this repository.
The stacked Kubernetes control plane is managed using [HAProxy and Keepalived]([https://github.com/kubernetes/kubeadm/blob/master/docs/ha-considerations.md#keepalived-and-haproxy) running as static pods on the control plane VMs.
## Requirements
To use this repository you will need the following on your local machine:
* Linux
* Ansible
* Terraform >= v0.13
* libvirt with a `default` storage pool - the [`network module`](https://github.com/jamonation/terraform-libvirt-k8s-lab/tree/main/terraform/modules/network) in this repository will define a network for you
* [terraform-provider-libvirt](https://github.com/dmacvicar/terraform-provider-libvirt)
* Enough CPU, RAM, and disk space to run two libvirt guests - the more the better!## Using this repository
**Before using terraform** add your **public*** key, excluding the `ssh-rsa` prefix in the various `variables.tf` files corresponding sections:
```
variable "ssh-public-key" {
description = "ssh-rsa key for terraform-libvirt user"
default = ""
}
```Running `terraform apply` with no variable arguments will create 5 Kubernetes nodes - 3 control plane, and 2 nodes for workloads. Each will use 2 CPUs, and have 2GB of RAM allocated.
**Before using ansible** you need to add the following to your `~/.ssh/config` to avoid having fingerprint check botch your ansible configuration:
```
Host 10.17.3.*
StrictHostKeyChecking no
```Once the VMs are up, running `ansible-playbook -i hosts bootstrap.yaml` in the `ansible` directory will bootstrap the Kubernetes control plane on one VM. The role will also generate a token for other `control-plane` nodes and will use that on the remaining nodes to join them to the cluster.
Kubernetes is accessed using a virtual IP that is managed by HAProxy and Keepalived. The IP address is `10.17.3.254`.
Running `ansible-playbook -i hosts local-config.yaml` will copy `admin.conf` to the playbook directory to be used along with `kubectl` as `kubectl --kubeconfig admin.conf get namespace`.
Each of the VMs has a static IP address for ease of access and keeping track of what lives where. The machines (in the default configuration) are:
```
k8s-controller-2 10.17.3.2
k8s-controller-3 10.17.3.3
k8s-controller-4 10.17.3.4k8s-nodes-2 10.17.3.10
k8s-nodes-3 10.17.3.11
```The guest hostname are indexed roughly according to their IP address - since 10.17.3.1 is the gateway, the nodes and IPs start at `2`.
**Todo: fix the k8s-nodes indexing to use an offset of 10.**
## Helpful resources, kudos, and credits
[How To Provision VMs on KVM with Terraform](https://computingforgeeks.com/how-to-provision-vms-on-kvm-with-terraform/) - a great resource to consult if you're just getting started with Terraform and KVM.
[Using the Libvirt Provisioner With Terraform for KVM](https://blog.ruanbekker.com/blog/2020/10/08/using-the-libvirt-provisioner-with-terraform-for-kvm/) - a more advanced example than the first
[
Dynamic Cloud-Init Content with Terraform File Templates
](https://grantorchard.com/dynamic-cloudinit-content-with-terraform-file-templates/) - templating `cloud-init` data wouldn't have been possible without this invaluable explanation.The [`terraform-provider-libvirt` documentation](https://github.com/dmacvicar/terraform-provider-libvirt) of course!
[How To Create a Kubernetes Cluster Using Kubeadm on Ubuntu 18.04](https://www.digitalocean.com/community/tutorials/how-to-create-a-kubernetes-cluster-using-kubeadm-on-ubuntu-18-04) - this tutorial formed the basis for the Ansible roles