Persist and encrypt the Vault client cache
By default, the Vault client cache does not persist. You can use the transit secrets engine with Vault Secrets Operator (VSO) to store and encrypt the client cache in your Vault server.
Dynamic secrets best practice
We strongly recommend persisting and encrypting the client cache if you use Vault dynamic secrets, so that dynamic secret leases are maintained through restarts and upgrades.
Before you start
- You must have Vault Secrets Operator installed.
- You must have the
transit
secrets engine enabled. - You must have the
kubernetes
authentication engine enabled.
Step 1: Configure a key and policy for VSO
Use the Vault CLI or Terraform to add a key to transit
and define policies
for encrypting and decrypting cache information:
export VAULT_NAMESPACE=<VAULT_NAMESPACE>export VAULT_TRANSIT_PATH=<VAULT_TRANSIT_PATH> vault write -f ${VAULT_TRANSIT_PATH}/keys/vso-client-cache vault policy write operator - <<EOHpath "${VAULT_TRANSIT_PATH}/encrypt/vso-client-cache" { capabilities = ["create", "update"]}path "${VAULT_TRANSIT_PATH}/decrypt/vso-client-cache" { capabilities = ["create", "update"]}EOH
Step 2: Create a kubernetes authentication role
Use the Vault CLI or Terraform to create a Kubernetes authentication role for Vault Secrets Operator.
export VAULT_NAMESPACE=<VAULT_NAMESPACE> vault write auth/<VAULT_KUBERNETES_PATH>/role/operator \ bound_service_account_names=vault-secrets-operator-controller-manager \ bound_service_account_namespaces=vault-secrets-operator \ token_period="24h" \ token_policies=operator \ audience="vault"
Step 3: Configure a Vault connection for VSO
Use the Vault Secrets Operator API to add a VaultConnection between VSO and your Vault server.
Note
If you already have a connection for VSO, continue to the next stepapiVersion: secrets.hashicorp.com/v1beta1kind: VaultConnectionmetadata: name: local-vault-server namespace: vault-secrets-operatorspec: address: 'https://vault.vault.svc.cluster.local:8200'
Step 4: Enable encrypted client cache storage
For Helm installs,
install (or upgrade) your server.clientCache
configuration:
controller: manager: clientCache: persistenceModel: direct-encrypted storageEncryption: enabled: true vaultConnectionRef: local-vault-server keyName: vso-client-cache transitMount: <VAULT_TRANSIT_PATH> namespace: <VAULT_NAMESPACE> method: kubernetes mount: <VAULT_KUBERNETES_PATH> kubernetes: role: operator serviceAccount: vault-secrets-operator-controller-manager tokenAudiences: ["vault"]
Optional: Verify client cache storage and encryption
Confirm the Vault Secrets Operator logs the following information on startup:
Starting manager {"clientCachePersistenceModel": "direct-encrypted", "clientCacheSize": 10000}
Confirm the Vault Secrets Operator logs a "Setting up Vault Client for storage encryption" message when authenticating to Vault on behalf of a user:
{"level":"info","ts":"2024-02-22T00:41:46Z","logger":"clientCacheFactory","msg":"Setting up Vault Client for storage encryption","persist":true,"enforceEncryption":true,"cacheKey":"kubernetes-59ebf88ccb963a22226bad"}
Verify the encrypted cache is stored as Kubernetes secrets under the correct namespace with the prefix
vso-cc-<auth method>
. For example:$ kubectl get secrets -n vault-secrets-operator...NAME TYPE DATA AGEvso-cc-kubernetes-0147431c618992b6adfed1 Opaque 2 73s...