Release 1.19
cert-manager is the easiest way to automatically manage certificates in Kubernetes and OpenShift clusters.
This release focuses on expanding platform compatibility, improving deployment flexibility, enhancing observability, and addressing key reliability issues.
Be sure to review all new features and changes below, and read the full release notes carefully before upgrading.
Important Upgrade Notes
When upgrading to cert-manager 1.19, use the latest patch version: v1.19.1.
There is a bug in v1.19.0 which may cause certificates to be re-issued unnecessarily. We fixed this in v1.19.1.
Major Themes
Deployment and Platform Compatibility
- The default network policy now includes
IPv6rules to improve support for dual-stack andIPv6enabled clusters. - The Helm chart has a new
global.nodeSelectorvalue, to set a single node selector across all cert-manager components. This simplifies the deployment of cert-manager. - The Helm chart has a new (experimental)
global.hostUsersflag which, if set tofalse, configures all the cert-manager Pods to use the User Namespace feature of Kubernetes>= 1.33. You can use this feature to reduce the damage a compromised container can do to the host or other pods in the same node. This new feature is disabled by default to maintain compatibility with Kubernetes< 1.33. In the future, when Kubernetes 1.32 reaches its end-of-life, the Helm chart value may be removed (or become a no-op) and cert-manager Pods will be configured to use user-namespaces by default.
ACME and Certificate Management
- There is a new feature gate
ACMEHTTP01IngressPathTypeExact, to allowingress-nginxusers to turn off the new default IngressPathType: Exactsetting. This is useful if you are using an old version ofingress-nginxwhich does not properly supportPathType: Exact. - The Issuer and ClusterIssuer custom resources have new fields which allow you to configure resource requests and resource limits for ACME HTTP-01 solver pods. This allows teams to override the global
--acme-http01-solver-resource-*flag values which are set by the platform administrator. Read HTTP01podTemplateOptions to learn more. - The ACME challenge authorization timeout has been increased to two minutes to reduce
error waiting for authorizationfailures. - There is now stricter solver validation to reject configurations that specify multiple ingress selection options (e.g.
class,ingressClassName,name). - There are DNS and API improvements. A new
protocolfield was added for therfc2136DNS01 provider. - The
CAInjectorMergingfeature has been promoted to BETA which means it is enabled by default. This means the feature, which configures the CA Injector to merges new CA certificates with existing ones instead of replacing them outright, is now considered stable and will be active unless explicitly disabled. - There are various reliability fixes related to certificates and CSRs: increased maximum parsable PEM sizes, corrected permitted URI domain handling in CSR name constraints, and improved admission error messages for malformed PEM data.
Observability, Reliability, and Maintenance
- There is a new Prometheus metric called
certmanager_certificate_challenge_status. - POTENTIALLY BREAKING: A high cardinality label, called
path, was removed from thecertmanager_acme_client_request_countandcertmanager_acme_client_request_duration_secondsmetrics. It is replaced with a new bounded cardinality label calledaction. This may require updates to dashboards and alerts.
Community
As always, we'd like to thank all of the community members who helped in this release cycle, including all below who merged a PR and anyone that helped by commenting on issues, testing, or getting involved in cert-manager meetings. We're lucky to have you involved.
A special thanks to:
@StingRayZA@armagankaratosun@hjoshi123@jcpunk@kinolaev@lunarwhite@mladen-rusev-cyberark@prasad89@quantpoet@sspreitzer
for their contributions, comments and support!
Also, thanks to the cert-manager maintainer team for their help in this release:
And finally, thanks to the cert-manager steering committee for their feedback in this release cycle:
v1.19.1
We reverted the CRD-based API defaults for Certificate.Spec.IssuerRef and CertificateRequest.Spec.IssuerRef after they were found to cause unexpected certificate renewals after upgrading to 1.19.0. We will try re-introducing these API defaults in cert-manager 1.20.
We fixed a bug that caused certificates to be re-issued unexpectedly if the issuerRef kind or group was changed to one of the "runtime" default values.
We upgraded Go to 1.25.3 to address the following security vulnerabilities: CVE-2025-61724, CVE-2025-58187, CVE-2025-47912, CVE-2025-58183, CVE-2025-61723, CVE-2025-58186, CVE-2025-58185, CVE-2025-58188, and CVE-2025-61725.
Changes since v1.19.0:
Bug or Regression
- BUGFIX: in case kind or group in the
issuerRefof a Certificate was omitted, upgrading to1.19.xincorrectly caused the certificate to be renewed (#8175,@cert-manager-bot) - Bump Go to 1.25.3 to fix a backwards incompatible change to the validation of DNS names in X.509 SAN fields which prevented the use of DNS names with a trailing dot (
#8177,@wallrj-cyberark) - Revert API defaults for issuer reference kind and group introduced in
1.19.0(#8178,@cert-manager-bot)
v1.19.0
Changes since v1.18.0:
Feature
- Add IPv6 rules to the default network policy (
#7726,@jcpunk) - Add
global.nodeSelectorto helm chart to allow for a singlenodeSelectorto be set across all services. (#7818,@StingRayZA) - Add a feature gate to default to Ingress
pathTypeExactin ACME HTTP01 Ingress challenge solvers. (#7795,@sspreitzer) - Add generated
applyconfigurationsallowing clients to make type-safe server-side apply requests for cert-manager resources. (#7866,@erikgb) - Added API defaults to issuer references group (cert-manager.io) and kind (Issuer). (
#7414,@erikgb) - Added
certmanager_certificate_challenge_statusPrometheus metric. (#7736,@hjoshi123) - Added
protocolfield forrfc2136DNS01 provider (#7881,@hjoshi123) - Added experimental field
hostUsersflag to all pods. Not set by default. (#7973,@hjoshi123) - Support configurable resource requests and limits for ACME HTTP01 solver pods through ClusterIssuer and Issuer specifications, allowing granular resource management that overrides global
--acme-http01-solver-resource-*settings. (#7972,@lunarwhite) - The
CAInjectorMergingfeature has been promoted to BETA and is now enabled by default (#8017,@ThatsMrTalbot) - The controller, webhook and ca-injector now log their version and git commit on startup for easier debugging and support. (
#8072,@prasad89) - Updated
certificatemetrics to the collector approach. (#7856,@hjoshi123)
Bug or Regression
- ACME: Increased challenge authorization timeout to 2 minutes to fix
error waiting for authorization(#7796,@hjoshi123) - BUGFIX: permitted URI domains were incorrectly used to set the excluded URI domains in the CSR's name constraints (
#7816,@kinolaev) - Enforced ACME HTTP-01 solver validation to properly reject configurations when multiple ingress options (
class,ingressClassName,name) are specified simultaneously (#8021,@lunarwhite) - Increase maximum sizes of PEM certificates and chains which can be parsed in cert-manager, to handle leaf certificates with large numbers of DNS names or other identities (
#7961,@SgtCoDFish) - Reverted adding the
global.rbac.disableHTTPChallengesRoleHelm option. (#7836,@inteon) - This change removes the
pathlabel of core ACME client metrics and will require users to update their monitoring dashboards and alerting rules if using those metrics. (#8109,@mladen-rusev-cyberark) - Use the latest version of
ingress-nginxin E2E tests to ensure compatibility (#7792,@wallrj)
Other (Cleanup or Flake)
- Helm: Fix naming template of
tokenrequestRoleBinding resource to improve consistency (#7761,@lunarwhite) - Improve error messages when certificates, CRLs or private keys fail admission due to malformed or missing PEM data (
#7928,@SgtCoDFish) - Major upgrade of Akamai SDK. NOTE: The new version has not been fully tested end-to-end due to the lack of cloud infrastructure. (
#8003,@hjoshi123) - Update kind images to include the Kubernetes 1.33 node image (
#7786,@wallrj) - Use
maps.Copyfor cleaner map handling (#8092,@quantpoet) - Vault: Migrate Vault E2E add-on tests from deprecated
vault-client-goto the newvault/apiclient. (#8059,@armagankaratosun)