Amazon Elastic Kubernetes Service
Import EKS Cluster
You can add an existing Kubernetes cluster and then manage it using KKP.
data:image/s3,"s3://crabby-images/dda7b/dda7b4bad108fcc21c634f4aae7adfd6938f6b0e" alt="External Cluster External Cluster"
- Pick
Elastic Kubernetes Engine
provider.
data:image/s3,"s3://crabby-images/295c3/295c3f5636aaf7b3be95e5d010ab35946bf452f1" alt="Select Provider Select Provider"
- Provide Credentials in either of the below mentioned ways:
Select a pre-created preset which stores the provider specific credentials.
Manually enter the credentials Access Key ID
, Secret Access Key
and select Region
Region is also kept as a part of a preset as it is a required value to create an EKS client.
- After user provides all required credentials, credentials will be validated.
Validation performed will only check if the credentials have Read
access.
data:image/s3,"s3://crabby-images/ab3ac/ab3ac5a1183dc76bcaf9f2aed6b228df85e955ab" alt="EKS credentials EKS credentials"
You should see the list of all available clusters in the region specified. Select the one and click the Import Cluster
button. Clusters can be imported only once in a single project. The same cluster can be imported in other projects.
data:image/s3,"s3://crabby-images/1a191/1a1912be7d365fba708aa1cb1e2ec69a6ba37450" alt="Select EKS cluster Select EKS cluster"
Create EKS Preset
Admin can create a preset on a KKP cluster using KKP Admin Panel
.
This Preset can then be used to Create/Import an EKS cluster.
- Click on
Admin Panel
from the menu.
data:image/s3,"s3://crabby-images/3cef3/3cef3dcd76920227f87149af75216d92fbdb42a2" alt="Select Admin Panel Select Admin Panel"
- Navigate to
Provider Presets
Page and Click on + Create Preset
button.
data:image/s3,"s3://crabby-images/c88b9/c88b98f862c5324140053003839fa5cac61ce7da" alt="Provider Preset Page Provider Preset Page"
data:image/s3,"s3://crabby-images/6a4b9/6a4b938f62a2a9200759472badadc6c98861174f" alt="Provide Preset Name Provide Preset Name"
- Choose
Elastic Kubernetes Service
from the list of providers.
data:image/s3,"s3://crabby-images/8f3b5/8f3b5e7b136f9d60cc0acbc0661438f31cea1da0" alt="Choose EKS Preset Choose EKS Preset"
- Enter EKS credentials and Click on
Create
button.
data:image/s3,"s3://crabby-images/934b9/934b9d440e5f9462c23022572e5156ea2e7650d4" alt="Enter Credentials Enter Credentials"
- You can now use created EKS Preset to Create or Import EKS Cluster.
data:image/s3,"s3://crabby-images/93009/93009ec79620ed2f2dbea0e379a34564fab190bd" alt="Select EKS Preset Select EKS Preset"
Cluster Details Page
After the cluster is added, the KKP controller retrieves the cluster kubeconfig to display all necessary information.
A healthy cluster has Running
state. Move the mouse cursor over the state indicator to get more details.
data:image/s3,"s3://crabby-images/f3465/f3465597037985bc8f8ab4c9d4101d1664ce012d" alt="EKS cluster EKS cluster"
You can also expand Events
to get information from the controller.
data:image/s3,"s3://crabby-images/b92df/b92df1ef37d2fee2ad3f7ec3b4f631634ab08f03" alt="Cluster Events Cluster Events"
You can also click on Machine Deployments
to get the details:
data:image/s3,"s3://crabby-images/9e4fe/9e4fe3f35f4dd13486574d66eef32dfe3ee2e883" alt="EKS Machine Deployment EKS Machine Deployment"
Update Cluster
Upgrade Version
To upgrade, click on the little dropdown arrow beside the Control Plane Version
on the cluster’s page and select the version from the dropdown. For more details about EKS available Kubernetes versions
Amazon EKS Kubernetes versions
data:image/s3,"s3://crabby-images/466b6/466b66e9f405969ed31f75449cff2eba1de6e05e" alt="Upgrade Available Upgrade Available"
data:image/s3,"s3://crabby-images/dd13c/dd13c5f7024948f4fd1b0c3db9e685f194c734fd" alt="Upgrade EKS Upgrade EKS"
If the upgrade version provided is valid, the cluster state will change to Reconciling
Edit the Machine Deployment
Only one operation can be performed at one point of time. If the replica count is updated then Kubernetes version upgrade will be disabled and vice versa.
Navigate to the cluster overview, scroll down to machine deployments.
Click on the edit icon next to the machine deployment you want to edit.
data:image/s3,"s3://crabby-images/b7e95/b7e95fb5e70d4057ae2ac3ea19cfa4f0c4b6d546" alt="Update EKS Machine Deployment Update EKS Machine Deployment"
Upgrade Kubernetes Version. Select the Kubernetes Version from the dropdown to upgrade the md.
Scale the replicas: In the popup dialog, you can increase or decrease the number of worker nodes that are managed by this machine deployment. Either specify the number of desired nodes or use the +
or -
to increase or decrease node count.
data:image/s3,"s3://crabby-images/5a75d/5a75db9d980b0e9e033bf563288eac7dbbb9e414" alt="Update EKS Machine Deployment Update EKS Machine Deployment"
Delete Cluster
Delete operation is not allowed for imported clusters.
Delete cluster operation allows to delete the cluster from the Provider. Click on the Delete
button.
data:image/s3,"s3://crabby-images/d4409/d4409871504ba7d99fad6a56e1ed8eec3d0f93ff" alt="Delete Cluster Delete Cluster"
Delete the Node Group
Navigate to the cluster overview, scroll down to machine deployments and click on the delete icon next to the machine deployment you want to delete.
data:image/s3,"s3://crabby-images/3fc24/3fc246bf88fb75ab6669d992edf4ef108b0bca51" alt="Delete EKS Machine Deployment Update EKS Machine Deployment"
Authenticating with EKS
The KKP platform allows getting kubeconfig file for the EKS cluster. The end-user must be aware that the kubeconfig expires
after some short period of time.
It’s recommended to create your kubeconfig file with the AWS CLI.
The AWS CLI uses credentials and configuration settings located in multiple places, such as the system or user environment
variables, local AWS configuration files, or explicitly declared on the command line as a parameter.
The AWS CLI stores sensitive credential information that you specify with aws configure in a local file named credentials,
in a folder named .aws
in your home directory. The less sensitive configuration options that you specify with aws configure
are stored in a local file named config
, also stored in the .aws
folder in your home directory.
Example:
~/.aws/credentials
[default]
aws_access_key_id=AKIAIOSFODNN7EXAMPLE
aws_secret_access_key=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY
Create kubeconfig file
Now you can create kubeconfig file automatically using the following command:
aws eks update-kubeconfig --region region-code --name cluster-name
By default, the resulting configuration file is created at the default kubeconfig path (.kube/config) in your home directory
or merged with an existing kubeconfig file at that location. You can specify another path with the --kubeconfig
option.