OIDC integration¶
Warning
The scenario and features described on this page are experimental. It's important to note that they have not been fully validated.
Kubernetes allows users to authenticate using various authentication mechanisms. One of these mechanisms is OIDC. Information on how Kubernetes interacts with OIDC providers can be found in the OpenID Connect Tokens section of the official Kubernetes documentation.
Follow the steps below to configure a CAPX cluster to use an OIDC identity provider.
Steps¶
- Generate a cluster.yamlfile with the required CAPX cluster configuration. Refer to the Getting Started page for more information on how to generate acluster.yamlfile. Do not apply thecluster.yamlfile.
- Edit the cluster.yamlfile and search for theKubeadmControlPlaneresource.
- Modify/add the spec.kubeadmConfigSpec.clusterConfiguration.apiServer.extraArgsattribute and add the required API server parameters. See the example below.
- Apply the cluster.yamlfile
- Log in with the OIDC provider once the cluster is provisioned
Example¶
kind: KubeadmControlPlane
spec:
  kubeadmConfigSpec:
    clusterConfiguration:
      apiServer:
        extraArgs:
            ...
            oidc-client-id: <oidc-client-id>
            oidc-issuer-url: <oidc-issuer-url>
            ...