As described in the docker
installation, Kerberos Vault and it's required services are running inside containers. Due to the nature of docker
and docker-compose
it's straight forward to setup Kerberos Vault in a few minutes. Using docker
will give you a good ramp-up speed, but will not provide you with a scalable and resilience deployment.
To overcome this and make Kerberos Vault scale, fault-tolerant and flexible, it's recommended to setup Kerberos Vault in a Kubernetes cluster.
Just like docker
, you bring your Kubernetes cluster where you want edge
or cloud
; private or public. Depending where you will host and how (e.g. managed Kubernetes cluster vs self-hosted) you'll have less/more responsibilities and/or control. Where and how is totally up to you, and your company preferences.
This installation guide will slight modify depending on if you are self-hosting or leveraging a managed Kubernetes service by a cloud provider. Within a self-hosted installation you'll be required to install specific Kubernetes resources yourself, such as persistent volumes, storage and a load balancer.
- Prerequisites
- Introduction
- Kerberos Vault
- Namespace
- Helm
- Ingress
- MongoDB
- Config Map
- Deployment
- Test out configuration
- Access the system
- Prerequisites
- Docker
- Kubernetes
- Untaint all nodes
- Calico
- Introduction
- Kerberos Vault
- MetalLB
- OpenEBS
- Proceed with managed Kubernetes
To simplify the installation we will start with the most common setup, where we will install Kerberos Vault on a managed Kubernetes services.
As of now there are many cloud providers such as, but not limited too, Azure, Google Cloud, AWS, and many more. Each cloud provider has build a management service on top of Kubernetes which takes over the heavy lifting of managing a cluster yourself. It makes specific resources such as built-in loadbalancers, storage, and more availble for your needs. The cloud provider manages all the complex things for you in the back-end and implements features such as load balancing, data replication etc.
For this installation we assume you have chosen a specific cloud provider that provides you with a manager Kubernetes. We'll assume you have the relevant .kubeconfig
configuration to be able to connect the api server of your Kubernetes installation. Make sure you can run following commands on you cluster.
kubectl get nodes
or
kubectl get pods --all-namespaces
Kerberos Vault requires some initial components to be installed. If you run Kerberos Vault in the same cluster as where you have a Kerberos Factory installed, there is not much to do, and you might skip the paragraphs with prerequisite.
If you plan to run Kerberos Vault in a different cluster (which is perfectly possible), you will need to make sure you complete the initial setup of the Kerberos Factory installation. To be more specific you will need to have following components running:
- Helm
- MongoDB
- Traefik (or alternatively Nginx ingress)
We'll assume you are starting an installation from scratch and therefore still need to install and configure previously mentioned components.
We'll start by cloning the configurations from our Github repo. This repo contains all the relevant configuration files required.
git clone https://github.com/kerberos-io/vault
Make sure to change directory to the kubernetes
folder.
cd kubernetes
A best practices is to isole tools and/or applications in a namespace, this will group relevant (micro)services. As a best practice we'll create a namespace kerberos-vault
.
kubectl create namespace kerberos-vault
This namespace will later be used to deploy the relevant services for Kerberos Vault.
Next we will install a couple of dependencies which are required for Kerberos Vault. Helm is a package manager for Kubernetes, it helps you to set up services more easily (this could be a MQTT broker, a database, etc). Instead of writing yaml files for every service we need, we use so-called Charts (libraries), that you can reuse and configure the, with the appropriate settings.
Use one of the preferred OS package managers to install the Helm client:
brew install helm
choco install kubernetes-helm
scoop install helm
gofish install helm
When using Kerberos Vault, it will persist references to the recordings stored in your storage provider in a MongoDB database. As used before, we are using helm
to install MongoDB in our Kubernetes cluster. Within the Kerberos Vault project we are using the latest official mongodb driver, so we support all major MongoDB versions (4.x, 5.x, 6.x, 7.x).
Have a look into the ./mongodb/values.yaml
file, you will find plenty of configurations for the MongoDB helm chart. To change the username and password of the MongoDB instance, go ahead and find the attribute where you can change the root password. Please note that we are using the official Bitnami Mongodb helm chart, so please use their repository for more indepth configuration.
Next to that you might also consider a SaaS MongoDB deployment using MongoDB Atlas or using a managed cloud like AWS, GCP, Azure or Alibaba cloud. A managed service takes away a lot of management and maintenance from your side (backups, security, sharing, etc). If you do want to install MongoDB in your own cluster then please continue with this tutorial.
helm repo add bitnami https://charts.bitnami.com/bitnami
kubectl create namespace mongodb
Note: If you are installing a self-hosted Kubernetes cluster, we recommend using openebs
. Therefore make sure to uncomment the global
.storageClass
attribute, and make sure it's using openebs-hostpath
instead.
helm install mongodb -n mongodb bitnami/mongodb --values ./mongodb/values.yaml
Once installed successfully, we should verify if the password has been set correctly. Print out the password using echo $MONGODB_ROOT_PASSWORD
and confirm the password is what you've specified in the values.yaml
file.
export MONGODB_ROOT_PASSWORD=$(kubectl get secret -n mongodb mongodb -o jsonpath="{.data.mongodb-root-password}" | base64 --decode)
echo $MONGODB_ROOT_PASSWORD
Kerberos Vault requires a configuration to connect to the MongoDB instance. To handle this configmap
map is created in the ./mongodb/mongodb.config.yaml
file. However you might also use the environment variables within the ./kerberos-vault/deployment.yaml
file to configure the mongodb connection.
Modify the MongoDB credentials in the ./mongodb/mongodb.config.yaml
, and make sure they match the credentials of your MongoDB instance, as described above. There are two ways of configuring the mongodb connection, either you provide a MONGODB_URI
or you specify the individual variables MONGODB_USERNAME
, MONGODB_PASSWORD
, etc.
As mentioned above a managed MongoDB is easier to setup and manage, for example for MongoDB Atlas, you will get a MongoDB URI in the form of "mongodb+srv://xx:xx@kerberos-hub.xxx.mongodb.net/?retryWrites=true&w=majority&appName=xxx"
. By applying this value into the MONGODB_URI
field, you will have setup your MongoDB connection successfully.
- name: MONGODB_URI
value: "mongodb+srv://xx:xx@kerberos-hub.xxx.mongodb.net/?retryWrites=true&w=majority&appName=xxx"
Once you applied this value, the other values like MONGODB_USERNAME
, MONGODB_PASSWORD
and others will be ignored. If you don't like the MONGODB_URI
format you can still use the old way of defining the MongoDB connection by providing the different values.
- name: MONGODB_USERNAME
value: "root"
- name: MONGODB_PASSWORD
--> value: "yourmongodbpassword"
Create the config map.
kubectl apply -f ./mongodb/mongodb.config.yaml -n kerberos-vault
To install the Kerberos Vault web app inside your cluster, simply execute below kubectl
command. This will create the deployment for us with the necessary configurations, and exposed it on internal/external IP address, thanks to our LoadBalancer
MetalLB or cloud provider.
kubectl apply -f ./kerberos-vault/deployment.yaml -n kerberos-vault
Verify that the Kerberos Vault got assigned an internal IP address.
kubectl get svc -n kerberos-vault
You should see the service vault-lb
being created, together with and IP address assigned from the MetalLB pool or cloud provider.
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
--> vault-lb LoadBalancer 10.107.209.226 192.168.1.81 80:30636/TCP 24m
By default Kerberos Vault deployment will use and create a LoadBalancer
. This means that Kerberos Vault will be granted an internal/external IP from which you can navigate to and consume the Kerberos Vault UI. However if you wish to use the Ingress
functionality by assigning a readable DNS name, you'll need to modify a few things.
First make sure to install either Traefik or Ingress-nginx, following sections below. Once you have chosen an Ingress
, open the ./kerberos-vault/ingress.yaml
configuration file. At the of the bottom file you will find an endpoint, similar to the Ingress
file below. Update the hostname to your own preferred domain, and add these to your DNS server or /etc/hosts
file (pointing to the same IP address as the ingress-nginx
IP address).
spec:
rules:
--> - host: vault.domain.com
http:
paths:
- path: /
backend:
serviceName: vault
servicePort: 80
Looking into the ./kerberos-vault/ingress.yaml
file, you will see that an nginx ingress will be created.
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: vault
annotations:
kubernetes.io/ingress.class: nginx
kubernetes.io/tls-acme: "true"
nginx.ingress.kubernetes.io/ssl-redirect: "true"
cert-manager.io/cluster-issuer: "letsencrypt-prod"
Once done, apply the Ingress
file.
kubectl apply -f ./kerberos-vault/ingress.yaml -n kerberos-vault
We are using an ingress to make the Kerberos Vault available, you might prefer another ingress, but we recommended nginx
as it is lightweight and easy to setup.
helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx
helm repo update
kubectl create namespace ingress-nginx
helm install ingress-nginx -n ingress-nginx ingress-nginx/ingress-nginx
If everything worked out as expected, you should now have following services in your cluster across different namespaces:
- MongoDB
- Ngin
- Kerberos Vault
It should look like this.
$ kubectl get pods -n kerberos-vault
NAME READY STATUS RESTARTS AGE
kerberos-vault-6f5c877d7c-hf77p 1/1 Running 0 2d11h
$ kubectl get pods -n mongodb
NAME READY STATUS RESTARTS AGE
mongodb-758d5c5ddd-qsfq9 1/1 Running 0 5m31s
$ kubectl get pods -n ingress-nginx
NAME READY STATUS RESTARTS AGE
nginx-ingress-nginx-controller-664f8f8d78-m4zck 1/1 Running 0 4d12h
Once everything is configured correctly, you should be able to access the Kerberos Vault application. By navigating to the internal/external IP address (LoadBalancer
) or domain (Ingress
) with your browser you will see the Kerberos Vault login page showing up.
You might have the requirement to self-host your Kubernetes cluster due to various good reasons. In this case the installation of Kerberos Vault will be slightly "more" difficult, in the sense that specific resources are not available by default; compared to the managed Kubernetes installation.
The good things is that installation of a self-hosted Kubernetes cluster, contains the same steps as a managed Kubernetes installation with a few extra resources on top.
We'll assume you have a blank Ubuntu 20.04 LTS machine (or multiple machines/nodes) at your posession. We'll start with updating the Ubuntu operating system.
apt-get update -y && apt-get upgrade -y
Let's install our container runtime docker
so we can run our containers.
apt install docker.io -y
Once installed modify the cgroup driver
, so kubernetes will be using it correctly. By default Kubernetes cgroup driver was set to systems but docker was set to systemd.
sudo mkdir /etc/docker
cat <<EOF | sudo tee /etc/docker/daemon.json
{
"exec-opts": ["native.cgroupdriver=systemd"],
"log-driver": "json-file",
"log-opts": {
"max-size": "100m"
},
"storage-driver": "overlay2"
}
EOF
sudo systemctl enable docker
sudo systemctl daemon-reload
sudo systemctl restart docker
After Docker being installed go ahead and install the different Kubernetes servicess and tools.
apt update -y
apt install apt-transport-https curl -y
curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | apt-key add
apt-add-repository "deb http://apt.kubernetes.io/ kubernetes-xenial main"
apt update -y && apt install kubelet=1.25.0-00 kubeadm=1.25.0-00 kubectl=1.25.0-00 -y
Make sure you disable swap, this is required by Kubernetes.
swapoff -a
And if you want to make it permanent after every boot.
sudo sed -i.bak '/ swap / s/^\(.*\)$/#\1/g' /etc/fstab
Special note: If you already had Kubernetes installed, make sure you are running latest version and/or have properly cleaned up previous installation.
kubeadm reset
rm -rf $HOME/.kube
Initiate a new Kubernetes cluster using following command. This will use the current CIDR. If you want to use another CIDR, specify following arguments: --pod-network-cidr=10.244.0.0/16
.
kubeadm init
Once successful you should see the following. Note the discovery token
which you need to use to connect additional nodes to your cluster.
Your Kubernetes control-plane has initialized successfully!
To start using your cluster, you need to run the following as a regular user:
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
You should now deploy a pod network to the cluster.
Run "kubectl apply -f [podnetwork].yaml" with one of the options listed at:
https://kubernetes.io/docs/concepts/cluster-administration/addons/
Then you can join any number of worker nodes by running the following on each as root:
kubeadm join 192.168.1.103:6443 --token ej7ckt.uof7o2iplqf0r2up \
--discovery-token-ca-cert-hash sha256:9cbcc00d34be2dbd605174802d9e52fbcdd617324c237bf58767b369fa586209
Now we have a Kubernetes cluster, we need to make sure we add make it available in our kubeconfig
. This will allow us to query our Kubernetes cluster with the kubectl
command.
mkdir -p $HOME/.kube
cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
chown $(id -u):$(id -g) $HOME/.kube/config
By default, and in this example, we only have one node our master node. In a production scenario we would have additional worker nodes. By default the master nodes are marked as tainted
, this means they cannot run workloads. To allow master nodes to run workloads, we need to untaint them. If we wouldn't do this our pods would never be scheduled, as we do not have worker nodes at this moment.
kubectl taint nodes <your_node_name> node-role.kubernetes.io/control-plane-
Calico is an open source networking and network security solution for containers, virtual machines, and native host-based workloads. (https://www.projectcalico.org/). We will use it as our network layer in our Kubernetes cluster. You could use otthers like Flannel aswell, but we prefer Calico.
curl https://raw.githubusercontent.com/projectcalico/calico/v3.26.1/manifests/calico.yaml -O
kubectl apply -f calico.yaml
As you might have read in the A. Managed Kubernetes
section, Kerberos Vault requires some initial components to be installed.
- Helm
- MongoDB
- Nginx
However for a self-hosted cluster, we'll need following components on top:
- MetalLB
- OpenEBS
For simplicity we'll start with the installation of MetalLB
and OpenEBS
. Afterwards we'll move back to the A. Managed Kubernetes
section, to install the remaining components.
We'll start by cloning the configurations from our Github repo. This repo contains all the relevant configuration files required.
git clone https://github.com/kerberos-io/vault
Make sure to change directory to the kubernetes
folder.
cd kubernetes
In a self-hosted scenario, we do not have fancy Load balancers and Public IPs from which we can "automatically" benefit. To overcome thism, solutions such as MetalLB - Baremetal Load Balancer - have been developed (https://metallb.universe.tf/installation/). MetalLB will dedicate an internal IP address, or IP range, which will be assigned to one or more Load Balancers. Using this dedicated IP address, you can reach your services or ingress.
kubectl apply -f https://raw.githubusercontent.com/metallb/metallb/v0.10.1/manifests/namespace.yaml
kubectl apply -f https://raw.githubusercontent.com/metallb/metallb/v0.10.1/manifests/metallb.yaml
kubectl create secret generic -n metallb-system memberlist --from-literal=secretkey="$(openssl rand -base64 128)"
After installing the different MetalLB components, we need to modify a configmap.yaml
file, which you can find here ./metallb/configmap.yaml
. This file contains information of how MetalLB can get and use internal IP's as LoadBalancers.
apiVersion: v1
kind: ConfigMap
metadata:
namespace: metallb-system
name: config
data:
config: |
address-pools:
- name: default
protocol: layer2
addresses:
--> - 192.168.1.200-192.168.1.210
You can change the IP range above to match your needs. MetalLB will use this range as a reference to assign IP addresses to your LoadBalancers. Once ready you can apply the configuration map.
kubectl apply -f ./metallb/configmap.yaml
Once installed, all services created in your Kubernetes cluster will receive an unique IP address as configured in the configmap.yaml
.
Some of the services we'll leverage such as MongoDB or Minio require storage, to persist their data safely. In a managed Kubernetes cluster, the relevant cloud provider will allocate storage automatically for you, as you might expect this is not the case for a self-hosted cluster.
Therefore we will need to prepare some storage or persistent volume. To simplify this we can leverage the OpenEBS storage solution, which can automatically provision PV (Persistent volumes) for us.
Let us start with installing the OpenEBS operator. Please note that you might need to change the mount folder. Download the openebs-operator.yaml
.
wget https://openebs.github.io/charts/openebs-operator.yaml
Scroll to the bottom, until you hit the StorageClass
section. Modify the BasePath
value to the destination (external mount) you prefer.
#Specify the location (directory) where
# where PV(volume) data will be saved.
# A sub-directory with pv-name will be
# created. When the volume is deleted,
# the PV sub-directory will be deleted.
#Default value is /var/openebs/local
- name: BasePath
value: "/var/openebs/local/"
Once you are ok with the BasePath
go ahead and apply the operator.
kubectl apply -f openebs-operator.yaml
Once done it should start installing several resources in the openebs
namespace. If all resources are created successfully we can launch the helm install
for MongoDB.
Now you're done with installing the self-hosted prerequisites, you should be able to proceed with the A. Managed Kubernetes section. This will install all the remaining resources.