Auth to GKE without gcloud

Installation
go install github.com/imjasonh/gke-auth@latest
Use
Once you've installed the Go binary, run it:
gke-auth --project=[MY_PROJECT] \
--location=[REGION_OR_ZONE] \
--cluster=[CLUSTER_NAME]
Now you have auth and kubeconfigs set up to use the cluster.
Or, using GitHub Actions:
- uses: imjasonh/gke-auth@v0.1.0
with:
project: [MY_PROJECT]
location: [REGION_OR_ZONE]
cluster: [CLUSTER_NAME]
You probably want to set up Workload Identity between your GitHub Actions workflow and your GCP project.
Test it with:
kubectl get pods
Why?
gcloud
is great.
It's like a Swiss army knife for the cloud, if a knife could do anything to a cloud.
It does so much.
It does soooo much!
Too much.
This leads it to be really huge.
Hundreds of megabytes of sweet delicious Python.
Python that has to be interpreted before it can even start running anything.
If you're downloading and installing and running gcloud
just to execute gcloud container clusters get-credentials
so you can switch to using kubectl
-- especially in a CI environment -- you're wasting a lot of time.
Installing gcloud
can take minutes, compared to just a few seconds with gke-auth
, even if you have to build it from source.
The example GitHub Actions workflow sets up Workload Identity auth to GKE and lists pods in a cluster in about seven seconds.
Compare that to the equivalent using gcloud
, which takes 33 seconds.