Rancher on Small DOKS Cluster
This guide demonstrates how to deploy a small DOKS (DigitalOcean Kubernetes Service) cluster with Rancher installed, using Terraform for infrastructure provisioning and Helm for application deployment.
Overview
Small DOKS Cluster for Rancher
This configuration deploys a lightweight DigitalOcean Kubernetes cluster consisting of two nodes, the NGINX ingress controller, and Rancher as the Kubernetes management platform. This setup is ideal for development and testing environments.
Terraform Script
Infrastructure Provisioning
The following Terraform script provisions the DOKS cluster:
provider "digitalocean" {
token = "${var.digitalocean_token}" # Replace with your DigitalOcean API token
}
module "kubernetes" {
source = "terraform-digitalocean-modules/kubernetes/digitalocean"
cluster_name = "rancher-doks-small"
region = "nyc3"
version = "1.27"
node_pool_size = 2
node_pool_type = "s-4vcpu-8gb"
}
Ingress NGINX Deployment
Deploy the NGINX ingress controller using Helm:
Create the Namespace
resource "kubernetes_namespace" "ingress_nginx" {
metadata {
name = "ingress-nginx"
}
}
Helm Chart Deployment
resource "helm_release" "nginx_ingress" {
name = "ingress-nginx"
namespace = kubernetes_namespace.ingress_nginx.metadata[0].name
repository = "https://kubernetes.github.io/ingress-nginx"
chart = "ingress-nginx"
version = "4.10.1"
set {
name = "controller.service.type"
value = "LoadBalancer"
}
set {
name = "controller.service.annotations.service\.beta\.kubernetes\.io/do-loadbalancer-sticky-sessions-type"
value = "cookies"
}
set {
name = "controller.service.annotations.service\.beta\.kubernetes\.io/do-loadbalancer-protocol"
value = "http"
}
set {
name = "controller.service.annotations.service\.beta\.kubernetes\.io/do-loadbalancer-healthcheck-path"
value = "/healthz"
}
}
Rancher Deployment
Create the Namespace
resource "kubernetes_namespace" "cattle_system" {
metadata {
name = "cattle-system"
}
}
Helm Chart Deployment
resource "helm_release" "rancher" {
name = "rancher"
namespace = kubernetes_namespace.cattle_system.metadata[0].name
repository = "https://releases.rancher.com/server-charts/latest"
chart = "rancher"
version = "2.7.0"
set {
name = "hostname"
value = "rancher.your-domain.com" # Replace with your hostname
}
set {
name = "ingress.tls.source"
value = "letsEncrypt"
}
set {
name = "letsEncrypt.email"
value = "admin@your-domain.com" # Replace with your email
}
set {
name = "letsEncrypt.environment"
value = "production"
}
}
Testing and Validation
Accessing Rancher
Once the Helm installation is complete, verify the Rancher pods:
kubectl get pods -n cattle-system
Access Rancher via the hostname you specified:
https://rancher.your-domain.com
Testing NGINX Ingress
Deploy a sample application and verify ingress access using the LoadBalancer endpoint.