Setting up TLS with Nginx Ingress
This guide provides a step-by-step tutorial on setting up TLS with Nginx Ingress on AWS EKS clusters
data:image/s3,"s3://crabby-images/be6a7/be6a7e6abdd29cd66718977bb43491087c28cf45" alt="Setting up TLS with Nginx Ingress"
Expose an Kubernetes service with TLS using NGINX Ingress on AWS EKS
Step 1: Create an AWS EKS Cluster
AWS EKS Kubernetes Cluster using eksctl Command
Step 1.1: Install AWS CLI (Mac OS)
Step 1.1.1: Download AWS CLI binary
curl "https://awscli.amazonaws.com/AWSCLIV2.pkg" -o "AWSCLIV2.pkg"
data:image/s3,"s3://crabby-images/20a73/20a73579f2b5b84251bd98d2b6429d01dd54e5d7" alt=""
Step 1.1.2: Install
sudo installer -pkg ./AWSCLIV2.pkg -target /
data:image/s3,"s3://crabby-images/f5e3f/f5e3f5bbcdf37e718d9cd4d52a18b9dd1a076486" alt=""
Step 1.1.3:Verify the installation
which aws
aws --version
data:image/s3,"s3://crabby-images/a1925/a19251af35732d3d5f03f282870f95aae3d84f6c" alt=""
Step 1.2: Configure AWS CLI
Step1.2.1: Login to AWS console as root user
Create IAM user
- username: kubedeveloper
- No AWS console access, Only programmatic access
data:image/s3,"s3://crabby-images/19257/1925795af4907bfa1c0500319e9979190a551afb" alt=""
data:image/s3,"s3://crabby-images/7c28b/7c28b30dff5b4f33ffcc39b3a986251fdae6dfdd" alt=""
data:image/s3,"s3://crabby-images/8cf27/8cf2763509014ac7c259197af663db62e673b235" alt=""
Step:1.2.2: Create Access and SecretAccessKey
Select the IAM user "kubedeveloper"
Navigate to Security Credentials
data:image/s3,"s3://crabby-images/84b22/84b22e18f99291c0d33eeed46d1ae26a22bffbaf" alt=""
Click Create access key
data:image/s3,"s3://crabby-images/9bd0f/9bd0f96cc194adbdfa42850a82c99e58fa9829de" alt=""
Select Use case : Command Line Interface (CLI) & check the Confirmation
data:image/s3,"s3://crabby-images/4a0e9/4a0e95437040f6b1ee4b91afdb1acbc22209e13a" alt=""
Set description tag - optional and Click create
data:image/s3,"s3://crabby-images/244ec/244ecad79769204000f1fc513d25690d69e384e8" alt=""
Step 1.2.3: Configure AWS CLI on Mac OS command-line
aws configure
data:image/s3,"s3://crabby-images/345db/345dbf5ac741026ff3e5c2a59e340a8f08ddb142" alt=""
Step 1.3: Install eksctl on Mac OS
Step 1.3.1: To download the latest release, run on Mac OS (arm64 architecture):
curl -sLO "https://github.com/eksctl-io/eksctl/releases/latest/download/eksctl_Darwin_arm64.tar.gz"
tar -xzvf eksctl_Darwin_arm64.tar.gz
sudo mv ./eksctl /usr/local/bin
data:image/s3,"s3://crabby-images/e6cb6/e6cb6257062797f9b296e72bf4792fec47013f12" alt=""
Ref: https://www.weave.works/oss/eksctl/
Step 1.3.2: Creating an AWS EKS Kubernetes Cluster using eksctl
Create Cluster configuration yaml file
vi cluster-config.yaml
apiVersion: eksctl.io/v1alpha5
kind: ClusterConfig
metadata:
name: kubelancer-cluster-2
region: us-east-1
nodeGroups:
- name: ng-1
instanceType: t4g.small
desiredCapacity: 2
volumeSize: 10
ssh:
allow: false
Let's create eks cluster on AWS using eksctl command
eksctl create cluster -f cluster-config.yaml
data:image/s3,"s3://crabby-images/5aa98/5aa98998db1afab9f87d0bb13e7e715b75be03c5" alt=""
Step 1.3.3: Use the following command to get kube-config
aws eks update-kubeconfig --name=kubelancer-cluster-2 --region=us-east-1
kubectl get node
data:image/s3,"s3://crabby-images/ad8ff/ad8ff251b7d7d0bb8f4d6b23079f45623131effd" alt=""
Step 2: Deploy the NGINX Ingress Controller
kubectl create namespace ingress-nginx
kubectl apply -f https://raw.githubusercontent.com/kubernetes/ingress-nginx/controller-v1.8.2/deploy/static/provider/cloud/deploy.yaml
data:image/s3,"s3://crabby-images/dd306/dd3062513cc5c7ed7345d4889d9029d9121c27a0" alt=""
Pre-flight check
kubectl get pods -n ingress-nginx
Output
data:image/s3,"s3://crabby-images/46c51/46c5146bd67ec8555ec458fc696f5f8237dd0ef6" alt=""
List Service
kubectl get svc --namespace=ingress-nginx
Output
data:image/s3,"s3://crabby-images/45d87/45d8766582ac058e75bb47dad63b106b92108043" alt=""
Step 3: Deploy a sample application
kubectl create ns dev
vi kubewebserver.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: kubewebserver
namespace: dev
labels:
app: kubewebserver
spec:
replicas: 1
selector:
matchLabels:
app: kubewebserver
template:
metadata:
labels:
app: kubewebserver
spec:
containers:
- name: kubewebserver
image: kubelancer/hello-kubelancer:v1
ports:
- containerPort: 80
---
apiVersion: v1
kind: Service
metadata:
name: kubewebserver-service
namespace: dev
labels:
app: kubewebserver-service
spec:
type: ClusterIP
ports:
- port: 80
targetPort: 80
protocol: TCP
selector:
app: kubewebserver
kubectl apply -f kubewebserver.yaml
Output
kubectl get deploy,svc -n dev
data:image/s3,"s3://crabby-images/1326e/1326e50a49673eda7ed06a93a7698fe9f7faed48" alt=""
Step 4: Create ingress without TLS
vi ingress-with-host.yaml
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: ingress-with-host-02
namespace: dev
annotations:
nginx.ingress.kubernetes.io/rewrite-target: /
spec:
ingressClassName: nginx
rules:
- host: webtest.kubelancer.in
http:
paths:
- path: /
pathType: Prefix
backend:
service:
name: kubewebserver-service
port:
number: 80
kubectl apply -f ingress-with-host.yaml
Output
kubectl get ingress -n dev
data:image/s3,"s3://crabby-images/5dc67/5dc6738a4e32923861fb84aef97f6516e51ccf40" alt=""
Output
curl http://webtest.kubelancer.in
curl http://webtest.kubelancer.in
Hello Kubelancer
Let we perform below steps to access same website using https://
To config SSL, we going to use Cert-Manager and Let's Encrypt in this Lab
In simple:
Cert Manager
cert-manager creates TLS certificates for workloads in your Kubernetes, also helps to renew the certificate.
cert-manager obtain certificates from a Let's Encrypt.
Let's Encrypt
To enable HTTPS for website, we need to purchase SSL certificate from Certificate Authority, which is costable. For demo or development environment, we have a choice to use free Certificate Authority (CA), that guy is Let’s Encrypt.
Step 5: Deploy cert-manager
kubectl apply -f https://github.com/cert-manager/cert-manager/releases/download/v1.14.4/cert-manager.yaml
data:image/s3,"s3://crabby-images/1410b/1410b61bc3852d86363755b091b06de21fdc36b1" alt=""
Output
kubectl get pods --namespace cert-manager
data:image/s3,"s3://crabby-images/75f6d/75f6de75aa38d255f792f859fb8704957c3e2bc5" alt=""
Step 6: Configure a Let's Encrypt Issuer
apiVersion: cert-manager.io/v1
kind: Issuer
metadata:
name: letsencrypt-prod
namespace: dev
spec:
acme:
server: https://acme-v02.api.letsencrypt.org/directory
email: noreply@gmail.com
privateKeySecretRef:
name: letsencrypt-prod
solvers:
- http01:
ingress:
ingressClassName: nginx
kubectl create -f issuer.yaml
kubectl get issuer -n dev
data:image/s3,"s3://crabby-images/3db6d/3db6dc43dcbaccb6f8d75369f0901e6bde71aaec" alt=""
Step 7: Deploy a TLS Ingress Resource
vi ingress-with-host.yaml
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: ingress-with-host-02
namespace: dev
annotations:
nginx.ingress.kubernetes.io/rewrite-target: /
cert-manager.io/issuer: "letsencrypt-prod"
spec:
ingressClassName: nginx
tls:
- hosts:
- webtest.kubelancer.in
secretName: kubewebserver-tls
rules:
- host: webtest.kubelancer.in
http:
paths:
- path: /
pathType: Prefix
backend:
service:
name: kubewebserver-service
port:
number: 80
kubectl apply -f ingress-with-host.yaml
kubectl get secret -n dev
data:image/s3,"s3://crabby-images/d94b3/d94b3a0930887a2ecdff3c05aab708977a4d9c51" alt=""
Step 8: Output
data:image/s3,"s3://crabby-images/26978/2697837ad87bb54ebc83292cc0f8d0993831e17b" alt=""
Now the website has secure connection