# Store configuration in Kubernetes Secrets

```json metadata
{
  "title": "Store configuration in Kubernetes Secrets",
  "description": "Store Redis Enterprise configuration items in Kubernetes Secrets for automatic updates and secure management.",
  "categories": ["docs","operate","kubernetes"],
  "tableOfContents": {"sections":[{"children":[{"id":"determine-your-cluster-fqdn","title":"Determine your cluster FQDN"},{"id":"use-a-kubernetes-secret-recommended","title":"Use a Kubernetes Secret (recommended)"},{"id":"embed-license-directly-in-rec-specification","title":"Embed license directly in REC specification"}],"id":"license-configuration","title":"License configuration"},{"children":[{"id":"default-behavior","title":"Default behavior"},{"id":"customize-the-credential-secret","title":"Customize the credential secret"}],"id":"cluster-credential-configuration","title":"Cluster credential configuration"},{"children":[{"id":"client-certificates-for-mtls","title":"Client certificates for mTLS"},{"id":"service-certificates","title":"Service certificates"},{"id":"internode-encryption-certificates","title":"Internode encryption certificates"}],"id":"tls-certificate-configuration","title":"TLS certificate configuration"},{"children":[{"id":"what-youll-see-in-the-pod","title":"What you'll see in the pod"},{"id":"what-the-secrets-contain","title":"What the Secrets contain"}],"id":"secrets-and-pem-files-in-redis-enterprise-pods","title":"Secrets and PEM files in Redis Enterprise pods"},{"id":"best-practices","title":"Best practices"},{"id":"see-also","title":"See also"}]}

,
  "codeExamples": []
}
```
You can store Redis Enterprise configuration items in Kubernetes Secrets for automatic updates and secure management. When you update these Secrets, the operator immediately reads the changes and propagates them to the Redis Enterprise Cluster (REC).

## License configuration

Redis Enterprise clusters require a valid license. You can apply licenses using Kubernetes Secrets (recommended) or embed them directly in the cluster specification.

### Determine your cluster FQDN

To configure licensing, you need your Redis Enterprise cluster's fully qualified domain name (FQDN). Use this format: `<REC-name>.<namespace>.svc.cluster.local`

For example: `my-rec.my-ns.svc.cluster.local`

### Use a Kubernetes Secret (recommended)

1. Create a secret from your license file:

    ```sh
    kubectl -n <namespace> create secret generic rec-license --from-file=license=./license.txt
    ```

2. Add the secret reference to your REC specification:

    ```yaml
    spec:
      licenseSecretName: rec-license
    ```

### Embed license directly in REC specification

Alternatively, you can embed the license directly in the REC YAML:

```yaml
spec:
  nodes: 3
  license: |
    ----- LICENSE START -----
    eai14c/y6XNVykffDQSPUsHKcmpgOFUlmyTBDUEZEz+GLbXAgQFOmxcdbR9J
    ...remaining license key content...
    ----- LICENSE END -----
```


You must include the pipe symbol (`|`) after `license:` and maintain proper indentation.


## Cluster credential configuration

Redis Enterprise clusters require admin credentials for the operator to manage the cluster. You can configure these credentials using Kubernetes Secrets.

### Default behavior

By default, the operator automatically creates a secret with a random username and auto-generated password during cluster creation. The secret name defaults to the cluster name.

### Customize the credential secret

You can customize the credential secret name during cluster creation using the `clusterCredentialSecretName` field in your REC specification. The secret must contain `username` and `password` fields.


The `clusterCredentialSecretName` field cannot be changed after cluster creation.


For detailed instructions, see [Customize the credential secret name](https://redis.io/docs/latest/operate/kubernetes/security/manage-rec-credentials#customize-the-credential-secret-name).

## TLS certificate configuration

You can store TLS certificates in Kubernetes Secrets to secure communication between clients and Redis Enterprise databases.

### Client certificates for mTLS

1. Create a secret with your client certificate:

    ```sh
    kubectl -n <namespace> create secret generic client-cert-secret --from-file=cert=<path-to-cert>
    ```

2. Add the secret to your REDB using the `clientAuthenticationCertificates` property. See [Add client certificates](https://redis.io/docs/latest/operate/kubernetes/security/add-client-certificates) for details.

### Service certificates

To configure certificates for proxy, API, or other services, create secrets with certificate and key files:

```sh
kubectl create secret generic <secret-name> \
  --from-file=certificate=</PATH/TO/certificate.pem> \
  --from-file=key=</PATH/TO/key.pem> \
  --from-literal=name=<proxy | api | cm | syncer | metrics_exporter>
```

### Internode encryption certificates

You can provide custom certificates for control plane and data plane internode encryption. Create separate secrets for each encryption type:

```sh
kubectl create secret generic cp-internode-cert \
  --from-file=certificate=</path/to/cp-certificate.pem> \
  --from-file=key=</path/to/cp-key.pem> \
  --from-literal=name=cp_internode_encryption
```

```sh
kubectl create secret generic dp-internode-cert \
  --from-file=certificate=</path/to/dp-certificate.pem> \
  --from-file=key=</path/to/dp-key.pem> \
  --from-literal=name=dp_internode_encryption
```

Reference these secrets in your REC specification under `spec.certificates`. See [Internode encryption](https://redis.io/docs/latest/operate/kubernetes/security/internode-encryption) for complete configuration details.

## Secrets and PEM files in Redis Enterprise pods

Redis Enterprise pods use Kubernetes Secrets and PEM-encoded certificates and keys for cluster formation, node identity, encrypted communication, and automated recovery. Their presence is expected — not a sign of compromise.

You create the Secrets. The operator references them and manages their lifecycle (for example, when you rename the credential Secret). TLS, license, and client authentication Secrets are always user-supplied.

### What you'll see in the pod

- **Mounted Secret volumes** at operator-managed paths such as:
  - `/opt/redislabs/credentials` — cluster admin credential Secret.
  - `/opt/redislabs/proxy` — call-home proxy credentials, when configured.
- **PEM-encoded certificates and keys** for TLS, internode encryption, and proxy or database endpoints. The operator applies these certificates through the cluster's REST API rather than as Secret volume mounts, and Redis Enterprise writes them to the pod filesystem. Exact paths vary by version and component.

### What the Secrets contain

Field names vary by deployment.

- **Cluster admin credentials** — `username` and `password` in the Secret named by `clusterCredentialSecretName`.
- **License** — `license` field in the Secret named by `licenseSecretName`.
- **Cluster Certificate Authority (CA)** — `ca.crt` or `ca.pem`. Validates peer certificates for mutual TLS. Optional.
- **Service TLS certificates and keys** for API, Cluster Manager (CM), metrics exporter, proxy, syncer, and LDAP. Fields: `certificate`, `cert`, or `tls.crt`, plus `key` or `tls.key`. See [Service certificates](#service-certificates).
- **Client authentication certificates** for databases. Set in the Redis Enterprise database (REDB) `clientAuthenticationCertificates` field.

## Best practices

- Store sensitive configuration in Secrets rather than directly in YAML files.
- Use `--from-file` to avoid manual base64 encoding.
- Create secrets in the same namespace as your REC or REDB resources.
- Use descriptive secret names for easy identification.
- Regularly rotate certificates and update secrets.

## See also

- [Manage REC credentials](https://redis.io/docs/latest/operate/kubernetes/security/manage-rec-credentials)
- [Manage REC certificates](https://redis.io/docs/latest/operate/kubernetes/security/manage-rec-certificates)
- [Add client certificates](https://redis.io/docs/latest/operate/kubernetes/security/add-client-certificates)
- [Redis Enterprise Cluster API reference](https://redis.io/docs/latest/operate/kubernetes/reference/api/redis_enterprise_cluster_api)

