How do I troubleshoot Amazon EKS cluster errors when I use a bastion host?
When I use kubectl client to connect to Amazon Elastic Kubernetes Service (Amazon EKS) from my bastion host, I receive the following error: "error: exec plugin: invalid apiVersion "client.authentication.k8s.io/v1alpha1"". I want to resolve this issue.
Published Aug 6, 2024
You receive the invalid apiVersion error when the version of kubectl that you're using is incompatible with your Kubernetes cluster's API version. This error typically occurs when you use an earlier version of the AWS Command Line Interface (AWS CLI) to update the kubeconfig file in $home/.kube/config. To resolve this issue, upgrade the AWS CLI to the most recent version. Then, update the kubeconfig file again. When you update the kubeconfig file, the apiVersion field in the kubeconfig file updates to the latest version (v1beta1) .
Note: If you receive errors when you run AWS CLI commands, then see Troubleshoot AWS CLI errors.
Note: You must use a kubectl version that's within one minor version difference of your Amazon EKS cluster control plane. For example, a 1.28 kubectl client works with Kubernetes 1.27, 1.28, and 1.29 clusters.
To install a supported kubectl version for your Amazon EKS cluster version, complete the following steps:
- To download kubectl, run the following command:
Note: Replace linux with your operating system, arm64 with your distribution, and 1.29 with your Kubernetes version.
- Copy the downloaded kubectl file to a folder in your path. If you already installed a version of kubectl, then create a $HOME/bin/kubectl:
Note: You must list $HOME/bin first in the $PATH.
- To verify the installed version of kubectl, run the following command:
- (Optional) Add the $HOME/bin path to your shell initialization file:
To update your kubeconfig file from v1alpha1 to v1beta1, run the following command:
Note: Replace clusterName with your cluster name and regionName with your AWS Region.
To test if you can connect to the cluster, run the following command: