Azure Key Vault provider for Secrets Store CSI Driver for Azure Kubernetes Service (AKS) configuration and troubleshooting options
Follow the steps in Use the Azure Key Vault provider for Secrets Store CSI Driver in an AKS cluster and Provide an identity to access the Azure Key Vault provider for Secrets Store CSI Driver in AKS. Once you complete these steps, you can apply extra configurations or perform troubleshooting.
Configuration options
Enable and disable auto-rotation
Once you enable auto-rotation for Azure Key Vault Secrets Provider, it updates the pod mount and the Kubernetes secret defined in the secretObjects
field of SecretProviderClass
. It does so by polling for changes periodically, based on the rotation poll interval you defined. The default rotation poll interval is two minutes.
When a secret updates in an external secrets store after initial pod deployment, the Kubernetes Secret and the pod mount periodically update depending on how the application consumes the secret data.
Mount the Kubernetes Secret as a volume: Use the auto-rotation and sync K8s secrets features of Secrets Store CSI Driver. The application needs to watch for changes from the mounted Kubernetes Secret volume. When the CSI Driver updates the Kubernetes Secret, the corresponding volume contents automatically update as well.
Application reads the data from the container filesystem: Use the rotation feature of Secrets Store CSI Driver. The application needs to watch for the file change from the volume mounted by the CSI driver.
Use the Kubernetes Secret for an environment variable: Restart the pod to get the latest secret as an environment variable. Use a tool such as Reloader to watch for changes on the synced Kubernetes Secret and perform rolling upgrades on pods.
Enable auto-rotation on a new AKS cluster
Enable auto-rotation of secrets on a new cluster using the
az aks create
command and enable theenable-secret-rotation
add-on.az aks create \ --name myAKSCluster2 \ --resource-group myResourceGroup \ --enable-addons azure-keyvault-secrets-provider \ --enable-secret-rotation \ --generate-ssh-keys
Enable auto-rotation on an existing AKS cluster
Update an existing cluster to enable auto-rotation of secrets using the
az aks addon update
command and theenable-secret-rotation
parameter.az aks addon update --resource-group myResourceGroup --name myAKSCluster2 --addon azure-keyvault-secrets-provider --enable-secret-rotation
Specify a custom rotation interval
Specify a custom rotation interval using the
az aks addon update
command with therotation-poll-interval
parameter.az aks addon update --resource-group myResourceGroup --name myAKSCluster2 --addon azure-keyvault-secrets-provider --enable-secret-rotation --rotation-poll-interval 5m
Disable auto-rotation
To disable auto-rotation, you first need to disable the add-on. Then, you can re-enable the add-on without the enable-secret-rotation
parameter.
Disable the secrets provider add-on using the
az aks addon disable
command.az aks addon disable --resource-group myResourceGroup --name myAKSCluster2 --addon azure-keyvault-secrets-provider
Re-enable the secrets provider add-on without the
enable-secret-rotation
parameter using theaz aks addon enable
command.az aks addon enable --resource-group myResourceGroup --name myAKSCluster2 --addon azure-keyvault-secrets-provider
If you are already using a SecretProviderClass
, you can update the add-on without disabling it first by using az aks addon enable
without specifying the enable-secret-rotation
parameter.
Sync mounted content with a Kubernetes secret
Note
The YAML examples in this section are incomplete. You need to modify them to support your chosen method of access to your key vault identity. For details, see Provide an identity to access the Azure Key Vault provider for Secrets Store CSI Driver.
You might want to create a Kubernetes secret to mirror your mounted secrets content. Your secrets sync after you start a pod to mount them. When you delete the pods that consume the secrets, your Kubernetes secret is also deleted.
Sync mounted content with a Kubernetes secret using the
secretObjects
field when creating aSecretProviderClass
to define the desired state of the Kubernetes secret, as shown in the following example YAML.apiVersion: secrets-store.csi.x-k8s.io/v1 kind: SecretProviderClass metadata: name: azure-sync spec: provider: azure secretObjects: # [OPTIONAL] SecretObjects defines the desired state of synced Kubernetes secret objects - data: - key: username # data field to populate objectName: foo1 # name of the mounted content to sync; this could be the object name or the object alias secretName: foosecret # name of the Kubernetes secret object type: Opaque # type of Kubernetes secret object (for example, Opaque, kubernetes.io/tls)
Note
Make sure the
objectName
in thesecretObjects
field matches the file name of the mounted content. If you useobjectAlias
instead, it should match the object alias.
Set an environment variable to reference Kubernetes secrets
Note
The example YAML demonstrates access to a secret through env variables and volume/volumeMount. This is for illustrative purposes. A typical application would use one method or the other. However, be aware that in order for a secret to be available through env variables, it first must be mounted by at least one pod.
Reference your newly created Kubernetes secret by setting an environment variable in your pod, as shown in the following example YAML.
kind: Pod apiVersion: v1 metadata: name: busybox-secrets-store-inline spec: containers: - name: busybox image: registry.k8s.io/e2e-test-images/busybox:1.29-1 command: - "/bin/sleep" - "10000" volumeMounts: - name: secrets-store01-inline mountPath: "/mnt/secrets-store" readOnly: true env: - name: SECRET_USERNAME valueFrom: secretKeyRef: name: foosecret key: username volumes: - name: secrets-store01-inline csi: driver: secrets-store.csi.k8s.io readOnly: true volumeAttributes: secretProviderClass: "azure-sync"
Access metrics
The Azure Key Vault provider
Metrics are served via Prometheus from port 8898, but this port isn't exposed outside the pod by default.
Access the metrics over localhost using
kubectl port-forward
.kubectl port-forward -n kube-system ds/aks-secrets-store-provider-azure 8898:8898 & curl localhost:8898/metrics
Metrics provided by the Azure Key Vault provider for Secrets Store CSI Driver
Metric | Description | Tags |
---|---|---|
keyvault_request | The distribution of how long it took to get from the key vault. | os_type=<runtime os> , provider=azure , object_name=<keyvault object name> , object_type=<keyvault object type> , error=<error if failed> |
grpc_request | The distribution of how long it took for the gRPC requests. | os_type=<runtime os> , provider=azure , grpc_method=<rpc full method> , grpc_code=<grpc status code> , grpc_message=<grpc status message> |
The Secrets Store CSI Driver
Metrics are served from port 8095, but this port isn't exposed outside the pod by default.
Access the metrics over localhost using
kubectl port-forward
.kubectl port-forward -n kube-system ds/aks-secrets-store-csi-driver 8095:8095 & curl localhost:8095/metrics
Metrics provided by the Secrets Store CSI Driver
Metric | Description | Tags |
---|---|---|
total_node_publish | The total number of successful volume mount requests. | os_type=<runtime os> , provider=<provider name> |
total_node_unpublish | The total number of successful volume unmount requests. | os_type=<runtime os> |
total_node_publish_error | The total number of errors with volume mount requests. | os_type=<runtime os> , provider=<provider name> , error_type=<error code> |
total_node_unpublish_error | The total number of errors with volume unmount requests. | os_type=<runtime os> |
total_sync_k8s_secret | The total number of Kubernetes secrets synced. | os_type=<runtime os , provider=<provider name> |
sync_k8s_secret_duration_sec | The distribution of how long it took to sync the Kubernetes secret. | os_type=<runtime os> |
total_rotation_reconcile | The total number of rotation reconciles. | os_type=<runtime os> , rotated=<true or false> |
total_rotation_reconcile_error | The total number of rotation reconciles with errors. | os_type=<runtime os> , rotated=<true or false> , error_type=<error code> |
total_rotation_reconcile_error | The distribution of how long it took to rotate secrets-store content for pods. | os_type=<runtime os> |
Migrate from open-source to AKS-managed Secrets Store CSI Driver
Uninstall the open-source Secrets Store CSI Driver using the following
helm delete
command.helm delete <release name>
Note
If you installed the driver and provider using deployment YAMLs, you can delete the components using the following
kubectl delete
command.# Delete AKV provider pods from Linux nodes kubectl delete -f https://raw.githubusercontent.com/Azure/secrets-store-csi-driver-provider-azure/master/deployment/provider-azure-installer.yaml # Delete AKV provider pods from Windows nodes kubectl delete -f https://raw.githubusercontent.com/Azure/secrets-store-csi-driver-provider-azure/master/deployment/provider-azure-installer-windows.yaml
Upgrade your existing AKS cluster with the feature using the
az aks enable-addons
command.az aks enable-addons --addons azure-keyvault-secrets-provider --name myAKSCluster --resource-group myResourceGroup
Troubleshooting
For troubleshooting steps, see Troubleshoot Azure Key Vault Provider for Secrets Store CSI Driver.
Next steps
To learn more about the Azure Key Vault provider for Secrets Store CSI Driver, see the following resources:
Azure Kubernetes Service