Overview
CKS issues OIDC-compliant ServiceAccount tokens to pods. Workloads can use these tokens to authenticate to external services like Google Cloud Platform (GCP) by establishing OIDC trust. This eliminates the need for long-lived credentials and lets you scope access to cloud resources per ServiceAccount. Benefits of this approach:- No credentials are stored in secrets or container images.
- Tokens are short-lived and rotated automatically by Kubernetes.
- IAM permissions can be tightly scoped to individual ServiceAccounts.
- No TLS thumbprint management is required, as with AWS.
- Pod requests access: The
gcs-clientpod uses its mounted OIDC token. - GCP validates identity: Google Cloud verifies the token against your CKS cluster’s OIDC endpoint.
- Impersonation granted: GCP lets the pod impersonate the
gcs-readerservice account. - Resource access: The pod can read from your GCS bucket using temporary credentials.
Prerequisites
Before you begin, ensure you have the following:CoreWeave requirements
- CKS cluster: A CoreWeave Kubernetes Service cluster with OIDC Workload Identity enabled.
- Cluster access:
kubectlconfigured to access your CKS cluster. - Cluster details: Your cluster’s OIDC issuer URL (instructions to find this are included in this tutorial).
Google Cloud Platform requirements
- GCP project: A Google Cloud Platform project where you’ll configure Workload Identity.
- GCP permissions: Your GCP account must have the following IAM roles:
Workload Identity Pool Admin(to create pools and providers).Service Account Admin(to create and manage service accounts).Project IAM Admin(to bind service accounts to workload identities).
- GCS bucket: A Google Cloud Storage bucket for testing (or permission to create one).
Command line tools
- gcloud CLI: Google Cloud SDK installed and authenticated.
- kubectl: Kubernetes command line tool configured for your CKS cluster.
GCP project information
You’ll need these values during the tutorial. Gather them beforehand:- Project ID: Your GCP project ID (for example,
my-project-123). - Project Number: Your GCP project number (numeric, for example,
123456789012).
Verify your setup
Test that everything is configured correctly:Set up Kubernetes resources
Before configuring GCP, you need to create the Kubernetes namespace and ServiceAccount that you grant access to GCS. These resources represent the identity that GCP trusts through Workload Identity Federation. The following sections describe how to create the namespace, ServiceAccount, and verify them.Create the namespace
Create a namespace calledfoo where your workloads will run:
Create the ServiceAccount
Create a ServiceAccount calledbar that your pods will use:
Verify the resources
Confirm both resources were created successfully:- Namespace
fooinActivestatus. - ServiceAccount
barexists in thefoonamespace. - ServiceAccount has default token secrets (projected OIDC tokens replace these).
Map Kubernetes resources to GCP identities
These Kubernetes resources will map to GCP identities as follows:- Namespace:
foo→ GCP attributeattribute.k8s_ns=foo. - ServiceAccount:
bar→ GCP attributeattribute.k8s_sa=bar.
foo/bar) to ensure only pods running with this ServiceAccount in this namespace can access your GCS resources.
Get the OIDC issuer URL from CKS
With the Kubernetes resources in place, the next step is to gather the cluster details that GCP needs to trust tokens issued by CKS. To use identity federation, you must know the OIDC Issuer URL of your CKS cluster. This is the base URL that serves token metadata and keys. The URL is formatted as a valid HTTPS URL, such as:https://oidc.cks.coreweave.com/id/[CLUSTER-ID].
You can obtain it in a few ways:
- CKS Console
- CKS API
- Terraform
- In the Cloud Console, navigate to the Clusters page.
- Click the name of the cluster to expand the cluster details panel.
- The OIDC Issuer URL is displayed in the Overview section.
Create a workload identity pool in GCP
With the issuer URL in hand, you can now configure the GCP side of the trust relationship. A workload identity pool is the GCP construct that groups external identities (in this case, your CKS pods) so that IAM policies can reference them.-
Create a pool to represent trusted external identities (your CKS pods):
-
Confirm the pool was created successfully:
Expected output should show:
state: ACTIVE.name: projects/PROJECT_NUMBER/locations/global/workloadIdentityPools/k8s-pool.
Workload Identity Pool Adminrole and are authenticated to the correct GCP project.
Create an OIDC provider in the pool
The pool now exists, but it isn’t yet configured to validate or interpret CKS tokens. Adding an OIDC provider specifies which issuer GCP trusts and how to map Kubernetes token claims to identity attributes based on namespace and ServiceAccount name.-
Configure the provider to trust your CKS OIDC issuer and extract identity information from tokens. Replace
[REGION]and[CLUSTER-ID]with your values. -
Check that the provider was configured correctly:
Expected output should include:
state: ACTIVE.- Your CKS OIDC issuer URL in the
issuerUrifield. - The attribute mapping you configured.
Create a Google Cloud service account and grant access
GCP now trusts your CKS cluster as an identity source, but federated identities still need a Google Cloud Service Account to impersonate to access GCP resources. In this section, you create that service account and grant it permission to read from GCS.-
Create the service account that CKS workloads impersonate:
-
Grant it permission to read from GCS. Replace
[PROJECT-ID]with your project ID.
Bind the CKS service account to the GSA
This binding connects the Kubernetes identity to the Google Cloud Service Account and controls which CKS pods can impersonategcs-reader.
-
Authorize the Kubernetes ServiceAccount
barin namespacefooto impersonate the GSA through the identity pool. Replace[PROJECT-NUMBER]and[PROJECT-ID]with your values. -
Check that the binding was created correctly. Replace
[PROJECT-ID]with your project ID.Expected output should include a binding with:role: roles/iam.workloadIdentityUser.memberscontaining yourprincipalSet://iam.googleapis.com/projects/...entry.
foo/bar ServiceAccount can impersonate the gcs-reader account.
Prepare a test GCS bucket
Before testing the authentication, create a GCS bucket or use an existing one:- Create new test bucket
- Use existing bucket
- Bucket names must be globally unique. Try adding a timestamp or random suffix.
- Ensure you have
Storage Adminpermissions in your GCP project.
Use a projected OIDC token in a pod to access GCS
With the trust relationship and IAM bindings in place, you’re ready to test end-to-end access from a pod. In your workload, configure a projected service account token with the proper audience. Create a pod YAML file calledgcs-client-pod.yaml with the following content, filling in the placeholder values for [PROJECT-NUMBER], [PROJECT-ID], and [YOUR-BUCKET-NAME].
gcs-client-pod.yaml
Deploy and test the pod
-
Apply the pod configuration:
-
Wait for the pod to start and check its status:
Error 403: Permission denied: Check that thegcs-readerservice account has access to your bucket.Invalid token: Verify your OIDC issuer URL matches your cluster’s endpoint.- Pod won’t start: Ensure the
barServiceAccount exists in thefoonamespace.
bar ServiceAccount in the foo namespace can access your GCS bucket using short-lived, automatically rotated credentials.