Docs Self-Managed Manage Kubernetes Security TLS Encryption Use cert-manager This is documentation for Self-Managed v24.1. To view the latest available version of the docs, see v24.2. Use cert-manager to manage TLS certificates When using cert-manager for TLS certificate management, you have the option to use a self-signed certificate or a certificate signed by a trusted certificate authority (CA). This topic provides instructions for each option. TLS, previously SSL, provides encryption for client-server communication. A server certificate prevents third parties from accessing data transferred between the client and server. Prerequisites You must have the following: Kubernetes cluster: Ensure you have a running Kubernetes cluster, either locally, such as with minikube or kind, or remotely. Kubectl. Ensure you have the kubectl command-line tool installed and configured to communicate with your cluster. cert-manager. Ensure you have cert-manager and its custom resource definitions (CRDs) installed. If you want to connect to your Redpanda cluster from outside Kubernetes, make sure to enable external access. Use a self-signed certificate By default, the Redpanda Helm chart uses cert-manager to generate four Certificate resources. These resources provide Redpanda brokers with self-signed TLS certificates for internal and external listeners. Type Default Certificates Internal redpanda-default-cert: Self-signed certificate for internal communications. redpanda-default-root-certificate: Root CA for the internal certificate. External redpanda-external-cert: Self-signed certificate for external communications. redpanda-external-root-certificate: Root CA for the external certificate. For each Certificate resource, a corresponding Secret resource exists, which contains the TLS files. Having separate self-signed certificates for internal and external connections provides security isolation. If an external certificate or its corresponding private key is compromised, it doesn’t affect the security of internal communications. The following steps explain how to set up self-signed certificates in your Redpanda cluster: Make sure that TLS is enabled: Helm + Operator Helm redpanda-cluster.yaml apiVersion: cluster.redpanda.com/v1alpha1 kind: Redpanda metadata: name: redpanda spec: chartRef: {} clusterSpec: tls: enabled: true kubectl apply -f redpanda-cluster.yaml --namespace <namespace> --values --set self-signed-tls.yaml tls: enabled: true helm upgrade --install redpanda redpanda/redpanda --namespace <namespace> --create-namespace \ --values self-signed-tls.yaml --reuse-values helm upgrade --install redpanda redpanda/redpanda --namespace <namespace> --create-namespace \ --set tls.enabled=true Make sure the Certificates are in a READY state. kubectl get certificate --namespace <namespace> NAME READY redpanda-default-cert True redpanda-default-root-certificate True redpanda-external-cert True redpanda-external-root-certificate True Connect to Redpanda You can use the rpk command-line client to test both internal and external connections to Redpanda. Test internal connections Your self-signed certificate’s SAN includes the internal addresses assigned to brokers by Kubernetes through the headless ClusterIP Service. As such, you can use rpk within the Redpanda container to securely communicate with the cluster. You can validate your internal connection to Redpanda with rpk by executing the following command: kubectl exec redpanda-0 --namespace <namespace> -c redpanda -- rpk cluster info Expected output: CLUSTER ======= redpanda.19ae8532-c8fa-49ed-8b35-82d74813db3a BROKERS ======= ID HOST PORT 0* redpanda-0.redpanda.<namespace>.svc.cluster.local. 9093 1 redpanda-.redpanda.<namespace>.svc.cluster.local. 9093 2 redpanda-2.redpanda.<namespace>.svc.cluster.local. 9093 Test external connections To test external connections, you must enable external access using a custom domain. See Prerequisites. The SAN list of your self-signed certificate does not contain the IP addresses of your worker nodes, but when you enable external access using a custom domain, that domain is included in the SAN list. Then, you can use rpk on your local machine to communicate with the cluster externally using the self-signed certificate for encryption. Configure external access to your Redpanda cluster using a custom domain. Your Redpanda brokers should advertise addresses in your custom domain. Install rpk on your local machine, not inside the container: Linux macOS Download the rpk archive for Linux. To download the latest version of rpk: curl -LO https://github.com/redpanda-data/redpanda/releases/latest/download/rpk-linux-amd64.zip To download a version other than the latest: curl -LO https://github.com/redpanda-data/redpanda/releases/download/v<version>/rpk-linux-amd64.zip Ensure that you have the folder ~/.local/bin: mkdir -p ~/.local/bin Add it to your $PATH: export PATH="~/.local/bin:$PATH" Unzip the rpk files to your ~/.local/bin/ directory: unzip rpk-linux-amd64.zip -d ~/.local/bin/ Run rpk --version to display the version of the rpk binary: rpk --version rpk version 24.1.1 (rev b5ade3f40) If you don’t have Homebrew installed, install it. Install rpk: brew install redpanda-data/tap/redpanda Run rpk --version to display the version of the rpk binary: rpk --version rpk version 24.1.1 (rev b5ade3f40) This method installs the latest version of rpk, which is supported only with the latest version of Redpanda. Save the external root CA to your local file system outside Kubernetes: kubectl --namespace <namespace> get secret redpanda-external-root-certificate -o go-template='{{ index .data "ca.crt" | base64decode }}' > ca.crt Configure rpk to connect to your cluster using the pre-configured profile: rpk profile create --from-profile <(kubectl get configmap --namespace <namespace> redpanda-rpk -o go-template='{{ .data.profile }}') <profile-name> Test the connection: rpk cluster info Use a public CA certificate Certificates from a public CA are trusted by default. You can configure the Helm chart to use an Issuer resource or a ClusterIssuer resource to generate publicly trusted Certificates for external connections. These custom resources are managed by cert-manager. The Issuer or ClusterIssuer specifies the CA that will be used when generating certificates. If you select an ACME server such as Let’s Encrypt as the CA, cert-manager automatically handles the required HTTP01 or DNS01 ACME challenges to issue certificates. Create an Issuer in the same namespace as your Redpanda cluster, or create a ClusterIssuer in any namespace. For details, see the cert-manager documentation. Configure the Helm chart with your Issuer or ClusterIssuer. Replace the following placeholders: <issuer-name>: The name of your Issuer or ClusterIssuer resource. <issuer>: Issuer or ClusterIssuer. <custom-domain>: Your domain. Helm + Operator Helm redpanda-cluster.yaml apiVersion: cluster.redpanda.com/v1alpha1 kind: Redpanda metadata: name: redpanda spec: chartRef: {} clusterSpec: tls: enabled: true certs: external: issuerRef: name: <issuer-name> kind: <issuer> caEnabled: false external: domain: <custom-domain> kubectl apply -f redpanda-cluster.yaml --namespace <namespace> --values --set external-tls.yaml tls: enabled: true certs: default: issuerRef: name: <issuer-name> kind: <issuer> caEnabled: false external: domain: <custom-domain> helm upgrade --install redpanda redpanda/redpanda --namespace <namespace> --create-namespace \ --values external-tls.yaml helm upgrade --install redpanda redpanda/redpanda --namespace <namespace> --create-namespace \ --set tls.enabled=true \ --set tls.certs.default.issuerRef.name=<issuer-name> \ --set tls.certs.default.issuerRef.kind=<issuer> \ --set tls.certs.default.caEnabled=false \ --set external.domain=<custom-domain> By default, this certificate will be used to encrypt traffic between clients and all external listeners. You can select specific certificates for each external listener. See Configure Listeners in Kubernetes. Make sure the Certificates are in a READY state. kubectl get certificate --namespace <namespace> Connect to Redpanda You can use the rpk command-line client to test both internal and external connections to Redpanda. Test internal connections Validate your internal connection to Redpanda with rpk by executing the following command. kubectl exec redpanda-0 --namespace <namespace> -c redpanda -- rpk cluster info You should see the Kafka API endpoints for the internal listener. For example: CLUSTER ======= redpanda.271dac90-2dc8-48e4-9dc6-652f63684d73 BROKERS ======= ID HOST PORT 0* redpanda-0.redpanda.redpanda.svc.cluster.local. 9093 1 redpanda-1.redpanda.redpanda.svc.cluster.local. 9093 2 redpanda-2.redpanda.redpanda.svc.cluster.local. 9093 Kubernetes assigns the *.redpanda.redpanda.svc.cluster.local. DNS names to the brokers through the headless ClusterIP Service. These are internal Kubernetes addresses. Port 9093 is the default port of the internal listener for the Kafka API. Test external connections To test external connections, external access must be enabled on your cluster and your brokers must advertise an address that’s resolvable externally by your clients. To test external connections: Install rpk on your local machine, not inside the container: Linux macOS Download the rpk archive for Linux. To download the latest version of rpk: curl -LO https://github.com/redpanda-data/redpanda/releases/latest/download/rpk-linux-amd64.zip To download a version other than the latest: curl -LO https://github.com/redpanda-data/redpanda/releases/download/v<version>/rpk-linux-amd64.zip Ensure that you have the folder ~/.local/bin: mkdir -p ~/.local/bin Add it to your $PATH: export PATH="~/.local/bin:$PATH" Unzip the rpk files to your ~/.local/bin/ directory: unzip rpk-linux-amd64.zip -d ~/.local/bin/ Run rpk --version to display the version of the rpk binary: rpk --version rpk version 24.1.1 (rev b5ade3f40) If you don’t have Homebrew installed, install it. Install rpk: brew install redpanda-data/tap/redpanda Run rpk --version to display the version of the rpk binary: rpk --version rpk version 24.1.1 (rev b5ade3f40) This method installs the latest version of rpk, which is supported only with the latest version of Redpanda. If your TLS certificates were issued by a private CA, save the root CA to your local file system outside Kubernetes: kubectl --namespace <namespace> get secret <secret-name> -o go-template='{{ index .data "ca.crt" | base64decode }}' > ca.crt Configure rpk to connect to your cluster using the pre-configured profile: rpk profile create --from-profile <(kubectl get configmap --namespace <namespace> redpanda-rpk -o go-template='{{ .data.profile }}') <profile-name> Test the connection: rpk cluster info You should see the Kafka API endpoints for the external listener. For example: CLUSTER ======= redpanda.271dac90-2dc8-48e4-9dc6-652f63684d73 BROKERS ======= ID HOST PORT 0* redpanda-0.customredpandadomain.local 31092 1 redpanda-1.customredpandadomain.local 31092 2 redpanda-2.customredpandadomain.local 31092 The Helm chart configures brokers with these addresses using the values of the external.domain and/or external.addresses settings in the Helm values. These are external addresses that external clients use to connect. Port 31092 is the default node port of the external listener for the Kafka API. This node port is assigned to the Kubernetes Services. If your brokers external addresses are not resolvable, you can test external connections by sending API requests to the container port that’s assigned to the external listener. For example: kubectl exec redpanda-0 -n redpanda -c redpanda -- rpk cluster info -X brokers=redpanda-0.redpanda.redpanda.svc.cluster.local:9094 -X tls.ca=/etc/tls/certs/external/ca.crt Port 9094 is the default container port for the external Kafka API. For more details on connecting to Redpanda, see Connect to Redpanda in Kubernetes. Disable TLS If you disable TLS, Redpanda communicates over a plain-text network connection, where any malicious party can see all communication. To disable TLS for all listeners, set tls.enabled to false: no-tls.yaml tls: enabled: false To disable TLS for a specific listener, set tls.enabled to false for the listener. For example, to disable TLS for the internal Kafka API listener: listeners: kafka: tls: enabled: false Troubleshoot Here are some common troubleshooting scenarios and their solutions. For more troubleshooting steps, see Troubleshoot Redpanda in Kubernetes. Invalid large response size This error appears when your cluster is configured to use TLS, but you don’t specify that you are connecting over TLS. unable to request metadata: invalid large response size 352518912 > limit 104857600; the first three bytes received appear to be a tls alert record for TLS v1.2; is this a plaintext connection speaking to a tls endpoint? If you’re using rpk, ensure to add the -X tls.enabled flag, and any other necessary TLS flags such as the TLS certificate: kubectl exec <pod-name> -c redpanda --namespace <namespace> -- rpk cluster info -X brokers=<subdomain>.<domain>:<external-port> -X tls.enabled=true For all available flags, see the rpk command reference. Malformed HTTP response This error appears when a cluster has TLS enabled, and you try to access the admin API without passing the required TLS parameters. Retrying POST for error: Post "http://127.0.0.1:9644/v1/security/users": net/http: HTTP/1.x transport connection broken: malformed HTTP response "\x15\x03\x03\x00\x02\x02" If you’re using rpk, ensure to include the TLS flags. For all available flags, see the rpk command reference. x509: certificate signed by unknown authority This error appears when the Certificate Authority (CA) that signed your certificates is not trusted by your system. Check the following: Ensure you have installed the root CA certificate correctly on your local system. If using a self-signed certificate, ensure it is properly configured and included in your system’s trust store. If you are using a certificate issued by a CA, ensure the issuing CA is included in your system’s trust store. If you are using cert-manager, ensure it is correctly configured and running properly. Check the validity of your certificates. They might have expired. x509: certificate is not valid for any names This error indicates that the certificate you are using is not valid for the specific domain or IP address you are trying to use it with. This error typically occurs when there is a mismatch between the certificate’s Subject Alternative Name (SAN) or Common Name (CN) field and the name being used to access the broker. To fix this error, you may need to obtain a new certificate that is valid for the specific domain or IP address you are using. Ensure that the certificate’s SAN or CN entry matches the name being used, and that the certificate is not expired or revoked. cannot validate certificate for 127.0.0.1 This error appears if you are using a CA certificate when you try to establish an internal connection using localhost. For example: unable to request metadata: unable to dial: x509: cannot validate certificate for 127.0.0.1 because it doesn't contain any IP SANs To fix this error, you must either specify the public domain or use self-signed certificates: kubectl exec redpanda-0 -c redpanda --namespace <namespace> -- \ rpk cluster info \ -X brokers=<subdomain>.<domain>:<external-port> \ -X tls.enabled=true I/O timeout This error appears when your worker nodes are unreachable through the given address. Check the following: The address and port are correct. Your DNS records point to addresses that resolve to your worker nodes. Next steps Configure Authentication for Redpanda in Kubernetes Configure Listeners in Kubernetes Connect to Redpanda in Kubernetes Suggested reading Securing Redpanda in Kubernetes (Day 2 Ops) Redpanda Helm Specification Redpanda CRD Reference Back to top × Simple online edits For simple changes, such as fixing a typo, you can edit the content directly on GitHub. Edit on GitHub Or, open an issue to let us know about something that you want us to change. Open an issue Contribution guide For extensive content updates, or if you prefer to work locally, read our contribution guide . Was this helpful? thumb_up thumb_down group Ask in the community mail Share your feedback group_add Make a contribution TLS Encryption Use Secrets