added nginx ingress

This commit is contained in:
Karim Naufal 2021-10-05 07:35:42 +02:00
parent 0130b72fa8
commit f31fac8814
3 changed files with 24 additions and 12 deletions

View File

@ -62,7 +62,7 @@ gofish install kubectl
2. Generate an ssh key pair for your cluster, unless you already have one that you'd like to use. 2. Generate an ssh key pair for your cluster, unless you already have one that you'd like to use.
3. Rename terraform.tfvars.example to terraform.tfvars and replace the values from steps 1 and 2. 3. Rename terraform.tfvars.example to terraform.tfvars and replace the values from steps 1 and 2.
### (Optional) Customize other variables ### Customize other variables (Optional)
The number of control plane nodes and worker nodes, and the Hetzner datacenter location, can be customized by adding the variables to your newly created [terraform.tfvars](terraform.tfvars) file. The number of control plane nodes and worker nodes, and the Hetzner datacenter location, can be customized by adding the variables to your newly created [terraform.tfvars](terraform.tfvars) file.
@ -93,6 +93,16 @@ export KUBECONFIG=/<path-to>/kubeconfig.yaml
To get the path, of course, you could use the `pwd` command. To get the path, of course, you could use the `pwd` command.
### Ingress Controller (Optional)
To have a complete and useful setup, it is ideal to have an ingress controller running and it turns out that the Hetzner Cloud Controller allows us to automatically deploy a Hetzner Load Balancer that can be used by the ingress controller. We have chosen to use the Nginx ingress controller that you can install with the following command:
```sh
helm install --values=manifests/helm/nginx/values.yaml ingress-nginx ingress-nginx/ingress-nginx -n kube-system
```
_Note that the default geographic location and instance type of the load balancer can be changed by editing the [values.yaml](manifests/helm/nginx/values.yaml) file._
<!-- USAGE EXAMPLES --> <!-- USAGE EXAMPLES -->
## Usage ## Usage
@ -188,25 +198,25 @@ latest=$(curl -s https://api.github.com/repos/weaveworks/kured/releases | jq -r
kubectl apply -f https://github.com/weaveworks/kured/releases/download/$latest/kured-$latest-dockerhub.yaml kubectl apply -f https://github.com/weaveworks/kured/releases/download/$latest/kured-$latest-dockerhub.yaml
``` ```
- Last but not least, upgrading Cilium itself - Cilium and the Nginx ingress controller
```sh ```sh
helm repo update helm repo update
helm upgrade --values=manifests/helm/cilium/values.yaml cilium cilium/cilium -n kube-system helm upgrade --values=manifests/helm/cilium/values.yaml cilium cilium/cilium -n kube-system
helm upgrade --values=manifests/helm/nginx/values.yaml ingress-nginx ingress-nginx/ingress-nginx -n kube-system
``` ```
## Takedown ## Takedown
- To take down your cluster, it's simple: If you chose to install the Nginx ingress controller, you need to delete it first to release the load balancer, as follows:
```sh ```sh
terraform destroy -auto-approve helm delete ingress-nginx -n kube-system
``` ```
- Sometimes, the Hetzner network does not get deleted on its own (probably due to a temporary bug); we have to delete it manually after running the first command and re-run it. Then you can proceed to taking down the rest of the cluster with:
```sh ```sh
hcloud network delete k3s-net
terraform destroy -auto-approve terraform destroy -auto-approve
``` ```

View File

@ -1,9 +1,11 @@
controller: controller:
kind: DaemonSet kind: DaemonSet
service: service:
type: LoadBalancer
annotations: annotations:
# adjust the location if you have customized it in terraform.tfvars
load-balancer.hetzner.cloud/location: "fsn1"
load-balancer.hetzner.cloud/use-private-ip: "true" load-balancer.hetzner.cloud/use-private-ip: "true"
load-balancer.hetzner.cloud/type: "lb11" # Adjust the location if you have customized it in terraform.tfvars
type: LoadBalancer # For more info on Hetzner Cloud locations, see https://docs.hetzner.com/general/others/data-centers-and-connection/
load-balancer.hetzner.cloud/location: "fsn1"
# For details about, load balancer instances, see https://www.hetzner.com/cloud/load-balancer
load-balancer.hetzner.cloud/type: "lb11"

View File

@ -57,7 +57,7 @@ resource "hcloud_server" "first_control_plane" {
} }
provisioner "local-exec" { provisioner "local-exec" {
command = "helm repo add cilium https://helm.cilium.io/ --kubeconfig ${path.module}/kubeconfig.yaml; helm install --values=manifests/helm/cilium/values.yaml cilium cilium/cilium -n kube-system --kubeconfig ${path.module}/kubeconfig.yaml" command = "helm repo add cilium https://helm.cilium.io/ --kubeconfig ${path.module}/kubeconfig.yaml; helm repo update --kubeconfig ${path.module}; helm install --values=manifests/helm/cilium/values.yaml cilium cilium/cilium -n kube-system --kubeconfig ${path.module}/kubeconfig.yaml"
} }
network { network {