Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
The Azure Key Vault provider for Secrets Store CSI Driver allows for the integration of an Azure Key Vault as a secret store with an Azure Kubernetes Service (AKS) cluster via a CSI volume.
Features
- Mounts secrets, keys, and certificates to a pod using a CSI volume.
- Supports CSI inline volumes.
- Supports mounting multiple secrets store objects as a single volume.
- Supports pod portability with the SecretProviderClassCRD.
- Supports Windows containers.
- Syncs with Kubernetes secrets.
- Supports autorotation of mounted contents and synced Kubernetes secrets.
Limitations
- A container using a ConfigMaporSecretas asubPathvolume mount does not receive automated updates when the secret is rotated. This is a Kubernetes limitation. To have the changes take effect, the application needs to reload the changed file by either watching for changes in the file system or by restarting the pod. For more information, see Secrets Store CSI Driver known limitations.
- The add-on creates a managed identity named azurekeyvaultsecretsprovider-xxxin the node resource group and assigns it to the Virtual Machine Scale Sets (VMSS) automatically. You can use this managed identity or your own managed identity to access the key vault. It's not supported to prevent creation of the identity.
Prerequisites
- If you don't have an Azure subscription, create a free account before you begin.
- Check that your version of the Azure CLI is 2.30.0 or later. If it's an earlier version, install the latest version.
Network
- If using network isolated clusters, it's recommended to set up private endpoint to access Azure Key Vault.
- If the cluster has outbound type userDefinedRoutingand uses a firewall device that can control outbound traffic based on domain names, such as Azure Firewall, ensure the required outbound network rules and FQDNs are allowed.
- If you're restricting Ingress to the cluster, make sure ports 9808 and 8095 are open.
Roles
- The identity used to with the SecretProviderClassneeds to haveKey Vault Certificate Userto accesskeyorcertificateobject types.
- The identity used to with the SecretProviderClassneeds to haveKey Vault Secrets Userto accesssecretobject type.
Create an AKS cluster with Azure Key Vault provider for Secrets Store CSI Driver support
- Create an Azure resource group using the - az group createcommand.- az group create --name myResourceGroup --location eastus2
- Create an AKS cluster with Azure Key Vault provider for Secrets Store CSI Driver capability using the - az aks createcommand with the- --enable-addons azure-keyvault-secrets-providerparameter. The add-on creates a user-assigned managed identity you can use to authenticate to your key vault. The following example creates an AKS cluster with the Azure Key Vault provider for Secrets Store CSI Driver enabled.- Note - If you want to use Microsoft Entra Workload ID, you must also use the - --enable-oidc-issuerand- --enable-workload-identityparameters, such as in the following example:- az aks create --name myAKSCluster --resource-group myResourceGroup --enable-addons azure-keyvault-secrets-provider --enable-oidc-issuer --enable-workload-identity --generate-ssh-keys- az aks create \ --name myAKSCluster \ --resource-group myResourceGroup \ --enable-addons azure-keyvault-secrets-provider \ --generate-ssh-keys
- The previous command creates a user-assigned managed identity, - azureKeyvaultSecretsProvider, to access Azure resources. The following example uses this identity to connect to the key vault that stores the secrets, but you can also use other identity access methods. Take note of the identity's- clientIdin the output.- ..., "addonProfiles": { "azureKeyvaultSecretsProvider": { ..., "identity": { "clientId": "<client-id>", ... } }
Note
After you enable this feature, AKS creates a managed identity named azurekeyvaultsecretsprovider-xxx in the node resource group and assigns it to the Virtual Machine Scale Sets (VMSS) automatically. You can use this managed identity or your own managed identity to access the key vault. It's not supported to prevent creation of the identity.
Upgrade an existing AKS cluster with Azure Key Vault provider for Secrets Store CSI Driver support
- Upgrade an existing AKS cluster with Azure Key Vault provider for Secrets Store CSI Driver capability using the - az aks enable-addonscommand and enable the- azure-keyvault-secrets-provideradd-on. The add-on creates a user-assigned managed identity you can use to authenticate to your key vault.- az aks enable-addons --addons azure-keyvault-secrets-provider --name myAKSCluster --resource-group myResourceGroup
Note
After you enable this feature, AKS creates a managed identity named azurekeyvaultsecretsprovider-xxx in the node resource group and assigns it to the Virtual Machine Scale Sets (VMSS) automatically. You can use this managed identity or your own managed identity to access the key vault. It's not supported to prevent creation of the identity.
Verify the Azure Key Vault provider for Secrets Store CSI Driver installation
- Get the AKS cluster credentials using the - az aks get-credentialscommand.- az aks get-credentials --name myAKSCluster --resource-group myResourceGroup
- Verify the installation is finished using the - kubectl get podscommand, which lists all pods with the- secrets-store-csi-driverand- secrets-store-provider-azurelabels in the kube-system namespace.- kubectl get pods -n kube-system -l 'app in (secrets-store-csi-driver,secrets-store-provider-azure)'- Your output should look similar to the following example output: - NAME READY STATUS RESTARTS AGE aks-secrets-store-csi-driver-4vpkj 3/3 Running 2 4m25s aks-secrets-store-csi-driver-ctjq6 3/3 Running 2 4m21s aks-secrets-store-csi-driver-tlvlq 3/3 Running 2 4m24s aks-secrets-store-provider-azure-5p4nb 1/1 Running 0 4m21s aks-secrets-store-provider-azure-6pqmv 1/1 Running 0 4m24s aks-secrets-store-provider-azure-f5qlm 1/1 Running 0 4m25s
- Verify that each node in your cluster's node pool has a Secrets Store CSI Driver pod and a Secrets Store Provider Azure pod running. 
Create or use an existing Azure Key Vault
- Create or update a key vault with Azure role-based access control (Azure RBAC) enabled using the - az keyvault createcommand or the- az keyvault updatecommand with the- --enable-rbac-authorizationflag. The name of the key vault must be globally unique. For more details on key vault permission models and Azure RBAC, see Provide access to Key Vault keys, certificates, and secrets with an Azure role-based access control- ## Create a new Azure key vault az keyvault create --name <keyvault-name> --resource-group myResourceGroup --location eastus2 --enable-rbac-authorization ## Update an existing Azure key vault az keyvault update --name <keyvault-name> --resource-group myResourceGroup --location eastus2 --enable-rbac-authorization
- Your key vault can store keys, secrets, and certificates. In this example, use the - az keyvault secret setcommand to set a plain-text secret called- ExampleSecret.- az keyvault secret set --vault-name <keyvault-name> --name ExampleSecret --value MyAKSExampleSecret
- Take note of the following properties for future use: - The name of the secret object in the key vault
- The object type (secret, key, or certificate)
- The name of your key vault resource
- The Azure tenant ID of the subscription
 
Next steps
In this article, you learned how to use the Azure Key Vault provider for Secrets Store CSI Driver in an AKS cluster. You now need to provide an identity to access the Azure Key Vault. To learn how, continue to the next article.
Azure Kubernetes Service