Configure mutual TLS authentication for applications running on Amazon EKS
Mahendra Revanasiddappa, Amazon Web Services
Summary
Certificate-based mutual Transport Layer Security (TLS) is an optional TLS component that provides two-way peer authentication between servers and clients. With mutual TLS, clients must provide an X.509 certificate during the session negotiation process. The server uses this certificate to identify and authenticate the client.
Mutual TLS is a common requirement for Internet of Things (IoT) applications and can be used for business-to-business applications or standards such as Open Banking.
This pattern describes how to configure mutual TLS for applications running on an Amazon Elastic Kubernetes Service (Amazon EKS) cluster by using an NGINX ingress controller. You can enable built-in mutual TLS features for the NGINX ingress controller by annotating the ingress resource. For more information about mutual TLS annotations on NGINX controllers, see Client certificate authentication
Important
This pattern uses self-signed certificates. We recommend that you use this pattern only with test clusters, and not in production environments. If you want to use this pattern in a production environment, you can use AWS Private Certificate Authority (AWS Private CA) or your existing public key infrastructure (PKI) standard to issue private certificates.
Prerequisites and limitations
Prerequisites
- An active Amazon Web Services (AWS) account. 
- An existing Amazon EKS cluster. 
- AWS Command Line Interface (AWS CLI) version 1.7 or later, installed and configured on macOS, Linux, or Windows. 
- The kubectl command line utility, installed and configured to access the Amazon EKS cluster. For more information about this, see Installing kubectl in the Amazon EKS documentation. 
- An existing Domain Name System (DNS) name to test the application. 
Limitations
- This pattern uses self-signed certificates. We recommend that you use this pattern only with test clusters, and not in production environments. 
Architecture

Technology stack
- Amazon EKS 
- Amazon Route 53 
- Kubectl 
Tools
- Amazon Elastic Kubernetes Service (Amazon EKS) helps you run Kubernetes on AWS without needing to install or maintain your own Kubernetes control plane or nodes. 
- Amazon Route 53 is a highly available and scalable DNS web service. 
- Kubectl is a command line utility that you use to interact with an Amazon EKS cluster. 
Epics
| Task | Description | Skills required | 
|---|---|---|
| Generate the CA key and certificate. | Generate the certificate authority (CA) key and certificate by running the following command. 
 | DevOps engineer | 
| Generate the server key and certificate, and sign with the CA certificate. | Generate the server key and certificate, and sign with the CA certificate by running the following command. 
 ImportantMake sure sure that you replace  | DevOps engineer | 
| Generate the client key and certificate, and sign with the CA certificate. | Generate the client key and certificate, and sign with the CA certificate by running the following command. 
 | DevOps engineer | 
| Task | Description | Skills required | 
|---|---|---|
| Deploy the NGINX ingress controller in your Amazon EKS cluster. | Deploy the NGINX ingress controller by using the following command. 
 | DevOps engineer | 
| Verify that the NGINX ingress controller service is running. | Verify that the NGINX ingress controller service is running by using the following command. 
 ImportantMake sure that the field of service address contains the Network Load Balancer’s domain name. | DevOps engineer | 
| Task | Description | Skills required | 
|---|---|---|
| Create a namespace in the Amazon EKS cluster. | Create a namespace called  
 This deploys the sample application to test mutual TLS. | DevOps engineer | 
| Task | Description | Skills required | 
|---|---|---|
| Create the Kubernetes deployment and service in the mtls namespace. | Create a file named  
 
Create the Kubernetes deployment and service in the  
 | DevOps engineer | 
| Verify that the Kubernetes deployment is created. | Run the following command to verify that the deployment is created and has one pod in available status. 
 | DevOps engineer | 
| Verify that the Kubernetes service is created. | Verify that the Kubernetes service is created by running the following command. 
 | DevOps engineer | 
| Task | Description | Skills required | 
|---|---|---|
| Create a secret for the ingress resource. | Run the folllowing command to create a secret for the NGINX ingress controller by using the certificates that you created earlier. 
 Your secret has a server certificate for the client to identify the server and a CA certificate for the server to verify the client certificates. | DevOps engineer | 
| Task | Description | Skills required | 
|---|---|---|
| Create the ingress resource in the mtls namespace. | Create a file named  
 Create the ingress resource in the  
 This means that the NGINX ingress controller can route traffic to your sample application. | DevOps engineer | 
| Verify that the ingress resource is created. | Verify that the ingress resource is created by running the following command. 
 ImportantMake sure that the address of the ingress resource shows the load balancer created for the NGINX ingress controller. | DevOps engineer | 
| Task | Description | Skills required | 
|---|---|---|
| Create CNAME record that points to the load balancer for the NGINX ingress controller. | Sign in to the AWS Management Console, open the Amazon Route 53 console, and create a Canonical Name (CNAME) record that points  For more information, see Creating records by using the Route 53 console in the Route 53 documentation. | DevOps engineer | 
| Task | Description | Skills required | 
|---|---|---|
| Test mutual TLS setup without certificates. | Run the following command. 
 You should receive the "400 No required SSL certificate was sent" error response. | DevOps engineer | 
| Test mutual TLS setup with certificates. | Run the following command. 
 You should receive the "mTLS is working" response. | DevOps engineer |