-
Notifications
You must be signed in to change notification settings - Fork 3
fix(deps): update module github.com/cloudnative-pg/cloudnative-pg to v1.28.0 #546
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: main
Are you sure you want to change the base?
fix(deps): update module github.com/cloudnative-pg/cloudnative-pg to v1.28.0 #546
Conversation
ℹ Artifact update noticeFile name: go.modIn order to perform the update(s) described in the table above, Renovate ran the
Details:
|
af25d0f to
ef201b7
Compare
ef201b7 to
2e33ca0
Compare
ecea4d0 to
cc88081
Compare
cc88081 to
161a767
Compare
be63981 to
9905a8a
Compare
667a064 to
b8519de
Compare
b8519de to
1ae6de6
Compare
19ca185 to
1ae6de6
Compare
1ae6de6 to
4c1bdfa
Compare
c3fa7d5 to
4c1bdfa
Compare
4c1bdfa to
78121ae
Compare
78121ae to
2f858dd
Compare
|
2f858dd to
ebfe5fb
Compare
ebfe5fb to
9da2efe
Compare
This PR contains the following updates:
v1.25.1->v1.28.0Warning
Some dependencies could not be looked up. Check the Dependency Dashboard for more information.
Release Notes
cloudnative-pg/cloudnative-pg (github.com/cloudnative-pg/cloudnative-pg)
v1.28.0Compare Source
Release date: Dec 9, 2025
Features
Quorum-Based Failover Promoted to Stable: Promoted the quorum-based failover feature, introduced experimentally in 1.27.0, to a stable API. This data-driven failover mechanism is now configured via the
spec.postgresql.synchronous.failoverQuorumfield, graduating from the previousalpha.cnpg.io/failoverQuorumannotation. (#8589)Declarative Foreign Data Management: Introduced comprehensive declarative management for Foreign Data Wrappers (FDW) by extending the
DatabaseCRD. This feature adds the.spec.fdwsand.spec.serversfields, allowing you to manage FDW extensions and their corresponding foreign servers directly from theDatabaseresource. This work was implemented by Ying Zhu (@EdwinaZhu) as part of the LFX Mentorship Program 2025 Term 2. (#7942, #8401)Changes
Updated the default PostgreSQL version to
18.1-system-trixie. (#9178)Updated the default PgBouncer version to 1.25.1 for new
Poolerdeployments. (#9367)Enhancements
Enabled simultaneous image and configuration changes when using
primaryUpdateMethod: restart, allowing you to update the container image (including PostgreSQL version or extensions) and PostgreSQL configuration settings in the same operation. Note that when usingprimaryUpdateMethod: switchover, image and configuration changes must still be performed separately to avoid configuration mismatches during the switchover process. (#8241)Improved network failure detection for replica instances by setting the default
tcp_user_timeoutto 5 seconds. This change helps replicas detect and recover from silent network drops more quickly. Previously, replicas could wait up to 127 seconds before detecting such failures; with the new timeout, they reconnect to the primary within 5 seconds. To preserve the previous behavior, setSTANDBY_TCP_USER_TIMEOUTto0in the operator configuration. (#9317)Adopted standard Kubernetes recommended labels (e.g.,
app.kubernetes.io/name) for all resources generated by CloudNativePG (Clusters, Backups, Poolers, etc.). Contributed by @JefeDavis. (#8087)Introduced
securityContextat the pod level andcontainerSecurityContextfor individual containers (includingpostgres,init, and sidecars). This provides granular control over security settings, replacing the previous cluster-widepostgresandoperatoruser settings. Contributed by @x0ddf. (#6614)Introduced the
alpha.cnpg.io/unrecoverable=trueannotation for replica pods. When applied, this annotation instructs the operator to permanently delete the instance by removing its Pod and PVCs, after which it will recreate the replica from the primary. (#8178)Introduced a new caching layer for user-defined monitoring queries to reduce load on the PostgreSQL database. (#8003)
Enhanced PgBouncer integration by automatically setting
auth_dbnameto thepgbouncerdatabase, simplifying auth setup. (#8671)Allowed providing stage-specific
pg_restoreoptions (preRestore,postRestore,dataRestore) during database import. Contributed by @hanshal101. (#7690)Added the PostgreSQL
majorVersionto theBackupobject's status for easier identification and management. (#8464)Enhanced cluster restore to wait for all init containers to complete before starting the restore process. This ensures that backup tools running in init containers finish preparing the data before the restore begins. The implementation correctly handles Kubernetes init container sidecars by ignoring those with
RestartPolicy=Always. (#9026)Added the
PGBOUNCER_IMAGE_NAMEoperator configuration parameter to allow overriding the default PgBouncer image. This is useful for air-gapped environments or when using internal registries. (#9232)cnpgplugin:Added a
--timeoutflag to thekubectl cnpg statuscommand for configuring the timeout for filesystem operations such as calculating cluster size. The default remains 10 seconds but can be adjusted for large clusters where operations may take longer. (#9201)Improved
cnpg reportto generate more shell-friendly file names. (#8984)Security
Allowed providing fine-grained custom TLS configurations for PgBouncer. The
PoolerCRD was extended withclientTLSSecret,clientCASecret,serverTLSSecret, andserverCASecretfields under.spec.pgbouncer. These fields enable users to supply their own certificates for both client-to-pooler and pooler-to-server connections, taking precedence over the operator-generated certificates. (#8692)Added optional TLS support for the operator's metrics server (port 8080). This feature is opt-in and enabled by setting the
METRICS_CERT_DIRenvironment variable, which instructs the operator to look fortls.crtandtls.keyfiles in the specified directory. When unset, the server continues to use HTTP for backward compatibility. (#8997)Enabled
cnpg report operatorto work with minimal permissions by making only the operator deployment required. All other resources (pods, secrets, config maps, events, webhooks, and OLM data) are now optional and collected on a best-efforts basis. The command gracefully handles permission errors for those resources by logging clear warnings and continuing report generation with available data, rather than failing completely. This enables least-privileged access, where users may have limited, namespace-scoped permissions. (#8982)Fixes
Improved resilience of all probe types (liveness, readiness, and startup) to transient Kubernetes API server connectivity issues. Probes now use a caching mechanism that falls back to cached cluster definitions during brief network interruptions, preventing unnecessary pod restarts and probe failures. (#9148)
Fixed the
CheckEmptyWalArchivesafeguard to run correctly when restoring from a volume snapshot using CNPG-I backup/WAL plugins (e.g.,plugin-barman-cloud). Previously, this check was skipped for plugin-based implementations. (#9306)Improved error reporting when ImageCatalog retrieval fails. The operator now emits a Warning event and logs errors for all failure types, not just
NotFounderrors, improving visibility into configuration issues. (#9266)Fixed TLS certificate verification issues when connecting to CNPG-I plugins by adding the
cnpg.io/pluginServerNameannotation. This allows customizing the DNS name used for certificate verification in environments where the plugin's certificate uses a different DNS name than the Service name. (#9222)Fixed an issue where the instance manager controller could fail to restart after an error, reporting a "controller already exists" message. The controller now uses
SkipNameValidationfor subsequent initialization attempts. Contributed by @mateusoliveira43. (#9123)Fixed incorrect WAL restore path handling in plugins when the destination path is absolute, preventing path duplication issues. Contributed by @Endevir. (#9093)
Fixed the
CREATE PUBLICATIONSQL generation for multi-table publications to be backward-compatible with PostgreSQL 13+. The previously generated syntax was only valid for PostgreSQL 15+ and caused syntax errors on older versions. (#8888)Fixed backup failures in complex pod definitions by reliably selecting the
postgrescontainer by name instead of by index. Contributed by @Joda89. (#8964)cnpgplugin:cnpg reportlog collection, especially when fetching previous logs. The collector now correctly fetches previous and current logs in separate requests and gracefully handles missing previous logs (e.g., on containers with no restart history), ensuring current logs are always collected. (#8992)Supported versions
v1.27.2Compare Source
Release date: Dec 9, 2025
!!! Warning Version 1.27 will be supported until 9 March 2026.
Changes
Updated the default PostgreSQL version to
18.1-system-trixie. (#9178)Updated the default PgBouncer version to 1.25.1 for new
Poolerdeployments. (#9367)Enhancements
Added the PostgreSQL
majorVersionto theBackupobject's status for easier identification and management. (#8464)Added the
PGBOUNCER_IMAGE_NAMEoperator configuration parameter to allow overriding the default PgBouncer image. This is useful for air-gapped environments or when using internal registries. (#9232)cnpgplugin:Added a
--timeoutflag to thekubectl cnpg statuscommand for configuring the timeout for filesystem operations such as calculating cluster size. The default remains 10 seconds but can be adjusted for large clusters where operations may take longer. (#9201)Improved
cnpg reportto generate more shell-friendly file names. (#8984)Fixes
Improved resilience of all probe types (liveness, readiness, and startup) to transient Kubernetes API server connectivity issues. Probes now use a caching mechanism that falls back to cached cluster definitions during brief network interruptions, preventing unnecessary pod restarts and probe failures. (#9148)
Fixed the
CheckEmptyWalArchivesafeguard to run correctly when restoring from a volume snapshot using CNPG-I backup/WAL plugins (e.g.,plugin-barman-cloud). Previously, this check was skipped for plugin-based implementations. (#9306)Improved error reporting when ImageCatalog retrieval fails. The operator now emits a Warning event and logs errors for all failure types, not just
NotFounderrors, improving visibility into configuration issues. (#9266)Fixed TLS certificate verification issues when connecting to CNPG-I plugins by adding the
cnpg.io/pluginServerNameannotation. This allows customizing the DNS name used for certificate verification in environments where the plugin's certificate uses a different DNS name than the Service name. (#9222)Fixed an issue where the instance manager controller could fail to restart after an error, reporting a "controller already exists" message. The controller now uses
SkipNameValidationfor subsequent initialization attempts. Contributed by @mateusoliveira43. (#9123)Fixed incorrect WAL restore path handling in plugins when the destination path is absolute, preventing path duplication issues. Contributed by @Endevir. (#9093)
Fixed the
CREATE PUBLICATIONSQL generation for multi-table publications to be backward-compatible with PostgreSQL 13+. The previously generated syntax was only valid for PostgreSQL 15+ and caused syntax errors on older versions. (#8888)Fixed backup failures in complex pod definitions by reliably selecting the
postgrescontainer by name instead of by index. Contributed by @Joda89. (#8964)cnpgplugin:cnpg reportlog collection, especially when fetching previous logs. The collector now correctly fetches previous and current logs in separate requests and gracefully handles missing previous logs (e.g., on containers with no restart history), ensuring current logs are always collected. (#8992)v1.27.1Compare Source
Release date: Oct 23, 2025
Changes
Delayed the decommissioning of native in-core support for Barman Cloud to at least version 1.29. (#8670)
Adopted the new format of
postgres-containersandpostgis-containersimages and image catalog artifacts, and updated the default PostgreSQL version to18.0-system-trixie(PostgreSQL 18 is now supported). (#8578, #8760, #8558)Deprecated the
monitoring.enablePodMonitorfield in theClusterandPoolerresources. This field will be removed in a future release. Users who rely onPodMonitorresources should create them manually instead. (#8753)Enhancements
Added support for overriding the PgBouncer
auth_type,server_tls_sslmode, andclient_tls_sslmodesettings, which were previously hardcoded. Default values remain consistent with the former behavior but can now be customized when required. (#8674)Added a
CHECKPOINTstep before PostgreSQL smart and fast shutdowns to reduce shutdown duration and replica promotion time, especially on systems with a highcheckpoint_timeout. (#8867)Added a warning in the instance manager for deprecated or unsupported OS versions, based on the official
postgres-containersproject. (#8601)Improved certificate parsing error reporting. Failures now log specific errors instead of a generic message, aiding troubleshooting. This is particularly relevant after the CVE-2025-58187 fix in Go 1.25.2 and 1.24.8, which may trigger parsing failures for invalid DNS SANs. (#8801)
Added a check to ensure the destination WAL archive path is empty when bootstrapping a cluster using the
pg_basebackupmethod, consistent with other bootstrap methods. (#8895)Added validation to prevent backups from running on hibernated clusters. Backups attempted on such clusters now fail with reason
ClusterIsHibernated, following the standard prerequisite check pattern. (#8870)Added support for
pprofprofiling. Instances can now enable thepproftool by adding thealpha.cnpg.io/enableInstancePprofannotation to theClusterresource for advanced debugging. (#7876)cnpgplugin:Updated the Flexible I/O Tester (FIO) image to
wallnerryan/fiotools-aio:v2, as provided by Ryan Wallner. (#8847)Enhanced the
cnpg status backupcommand to provide more detailed status information when using abarman-cloud-based backup plugin. (#8780, #8690)Fixes
Fixed backup restoration failures when using custom WAL segment sizes with parallel WAL recovery. The operator no longer manages the end-of-WAL file marker during restoration, preventing errors when backups span multiple WAL segments. (#8873)
Fixed a bug in major upgrades where a volume snapshot from a previous minor version could be incorrectly used to optimize replica creation. (#8475)
Fixed
initdbto wait for the application user secret before bootstrapping a new cluster, preventing potential race conditions. (#8663)Fixed configuration hash calculation to ignore internal configuration fields, preventing unnecessary reconciliations. (#8868)
Fixed the connection retry logic in the
cnpgiplugin. The reconciliation loop now detects connection pool changes correctly and uses exponential backoff to reduce "closed pool" errors. (#8554)Fixed volume snapshot usage during replica scaling to work with backup plugins. Previously, this optimization was only available with the in-tree backup implementation, but now clusters using backup plugins can also leverage volume snapshots when creating new replicas. (#8506)
Fixed the
Poolertemplating to correctly inherit settings for the bootstrap controller init container. (#8394)Fixed webhook errors to use the correct API group (
postgresql.cnpg.io) inPoolerand backup webhooks, ensuring consistent API error reporting. (#8485)Fixed a potential nil pointer dereference in the hibernation reconciler when handling errors. Contributed by @PascalBourdier. (#8756)
Fixed an issue in the environment cache where callers could inadvertently modify shared data. The
LoadEnvfunction now returns a copy of cached environment slices to prevent mutations from affecting the cache. (#8880)v1.27.0Compare Source
Release date: Aug 12, 2025
Important changes:
livenessProbeTimeout(default: 30 seconds).Features:
Dynamic loading of PostgreSQL extensions: Introduced the
.spec.postgresql.extensionsstanza for mounting PostgreSQL extensions, packaged as OCI-compliant container images, as read-only and immutable volumes inside instance pods. This allows dynamic extension management without rebuilding base images. (#7991).Logical decoding slot synchronization in HA clusters: Added the
synchronizeLogicalDecodingfield underspec.replicationSlots.highAvailabilityto enable automatic synchronization of logical decoding slots across high-availability clusters, ensuring logical replication subscribers continue seamlessly after a publisher failover (#7931).Primary Isolation Check: Promoted to stable the liveness pinger experimental feature introduced in 1.26, adding the
.spec.probes.liveness.isolationChecksection to enable primary isolation checks in the liveness probe by default. This improves the detection and handling of primary connectivity issues in Kubernetes environments (#7845).Enhancements:
Introduced an opt-in experimental feature that enables quorum-based failover to improve safety and data durability during failover events. This feature, also called failover quorum, can be activated via the
alpha.cnpg.io/failoverQuorumannotation. (#7572).Added support for user maps for predefined users such as
streaming_replica, allowing the use of self-managed client certificates with different Common Names in environments with strict policies or shared CAs, while still enabling replicas to join clusters using thestreaming_replicarole (#7725).Added a new
PhaseFailurePluginphase in theClusterstatus to improve observability of plugin-related failures (#7988).Made the
Backup.specfield immutable after creation, ensuring consistency and predictability in backup operations (#7904).Added
fqdn-uriandfqdn-jdbc-urifields in the user secret to simplify the retrieval of fully qualified domain name-based connection strings (#7852).CNPG-I:
Added
Postgresinterface support to the CNPG-I operator, continuing the transition toward a plugin-based architecture (#7179).Added
metricscapabilities to the CNPG-I instance webserver, enabling metrics exposure directly from the instance for better observability (#8033).Fixes
barman-cloudplugin using theswitchoverstrategy. Former primary Pods now restart correctly after WAL archiving fails due to missing plugin support. (#8236)Supported versions
v1.26.3Compare Source
Release date: Dec 9, 2025
!!! Warning This is the final release in the 1.26.x series. Users are strongly encouraged to upgrade to a newer minor version, as 1.26 is no longer supported.
Changes
Updated the default PostgreSQL version to
18.1-system-trixie. (#9178)Updated the default PgBouncer version to 1.25.1 for new
Poolerdeployments. (#9367)Enhancements
Added the PostgreSQL
majorVersionto theBackupobject's status for easier identification and management. (#8464)Added the
PGBOUNCER_IMAGE_NAMEoperator configuration parameter to allow overriding the default PgBouncer image. This is useful for air-gapped environments or when using internal registries. (#9232)cnpgplugin:cnpg reportto generate more shell-friendly file names. (#8984)Fixes
Fixed the
CheckEmptyWalArchivesafeguard to run correctly when restoring from a volume snapshot using CNPG-I backup/WAL plugins (e.g.,plugin-barman-cloud). Previously, this check was skipped for plugin-based implementations. (#9306)Fixed TLS certificate verification issues when connecting to CNPG-I plugins by adding the
cnpg.io/pluginServerNameannotation. This allows customizing the DNS name used for certificate verification in environments where the plugin's certificate uses a different DNS name than the Service name. (#9222)Fixed an issue where the instance manager controller could fail to restart after an error, reporting a "controller already exists" message. The controller now uses
SkipNameValidationfor subsequent initialization attempts. Contributed by @mateusoliveira43. (#9123)Fixed incorrect WAL restore path handling in plugins when the destination path is absolute, preventing path duplication issues. Contributed by @Endevir. (#9093)
Fixed the
CREATE PUBLICATIONSQL generation for multi-table publications to be backward-compatible with PostgreSQL 13+. The previously generated syntax was only valid for PostgreSQL 15+ and caused syntax errors on older versions. (#8888)Fixed backup failures in complex pod definitions by reliably selecting the
postgrescontainer by name instead of by index. Contributed by @Joda89. (#8964)cnpgplugin:cnpg reportlog collection, especially when fetching previous logs. The collector now correctly fetches previous and current logs in separate requests and gracefully handles missing previous logs (e.g., on containers with no restart history), ensuring current logs are always collected. (#8992)v1.26.2Compare Source
Release date: Oct 23, 2025
Changes
Delayed the decommissioning of native in-core support for Barman Cloud to at least version 1.29. (#8670)
Adopted the new format of
postgres-containersandpostgis-containersimages and image catalog artifacts, and updated the default PostgreSQL version to18.0-system-trixie(PostgreSQL 18 is now supported). (#8578, #8760, #8558)Deprecated the
monitoring.enablePodMonitorfield in theClusterandPoolerresources. This field will be removed in a future release. Users who rely onPodMonitorresources should create them manually instead. (#8753)Enhancements
Added support for overriding the PgBouncer
auth_type,server_tls_sslmode, andclient_tls_sslmodesettings, which were previously hardcoded. Default values remain consistent with the former behavior but can now be customized when required. (#8674)Added a
CHECKPOINTstep before PostgreSQL smart and fast shutdowns to reduce shutdown duration and replica promotion time, especially on systems with a highcheckpoint_timeout. (#8867)Added a warning in the instance manager for deprecated or unsupported OS versions, based on the official
postgres-containersproject. (#8601)Improved certificate parsing error reporting. Failures now log specific errors instead of a generic message, aiding troubleshooting. This is particularly relevant after the CVE-2025-58187 fix in Go 1.25.2 and 1.24.8, which may trigger parsing failures for invalid DNS SANs. (#8801)
Added a check to ensure the destination WAL archive path is empty when bootstrapping a cluster using the
pg_basebackupmethod, consistent with other bootstrap methods. (#8895)Added validation to prevent backups from running on hibernated clusters. Backups attempted on such clusters now fail with reason
ClusterIsHibernated, following the standard prerequisite check pattern. (#8870)Added support for
pprofprofiling. Instances can now enable thepproftool by adding thealpha.cnpg.io/enableInstancePprofannotation to theClusterresource for advanced debugging. (#7876)cnpgplugin:Updated the Flexible I/O Tester (FIO) image to
wallnerryan/fiotools-aio:v2, as provided by Ryan Wallner. (#8847)Enhanced the
cnpg status backupcommand to provide more detailed status information when using abarman-cloud-based backup plugin. (#8780, #8690)Fixes
Fixed backup restoration failures when using custom WAL segment sizes with parallel WAL recovery. The operator no longer manages the end-of-WAL file marker during restoration, preventing errors when backups span multiple WAL segments. (#8873)
Fixed a bug in major upgrades where a volume snapshot from a previous minor version could be incorrectly used to optimize replica creation. (#8475)
Fixed
initdbto wait for the application user secret before bootstrapping a new cluster, preventing potential race conditions. (#8663)Fixed the connection retry logic in the
cnpgiplugin. The reconciliation loop now detects connection pool changes correctly and uses exponential backoff to reduce "closed pool" errors. (#8554)Fixed volume snapshot usage during replica scaling to work with backup plugins. Previously, this optimization was only available with the in-tree backup implementation, but now clusters using backup plugins can also leverage volume snapshots when creating new replicas. (#8506)
Fixed the
Poolertemplating to correctly inherit settings for the bootstrap controller init container. (#8394)Fixed webhook errors to use the correct API group (
postgresql.cnpg.io) inPoolerand backup webhooks, ensuring consistent API error reporting. (#8485)Fixed a potential nil pointer dereference in the hibernation reconciler when handling errors. Contributed by @PascalBourdier. (#8756)
Fixed an issue in the environment cache where callers could inadvertently modify shared data. The
LoadEnvfunction now returns a copy of cached environment slices to prevent mutations from affecting the cache. (#8880)v1.26.1Compare Source
Release date: Jul 25, 2025
In memory of DJ Walker-Morgan.
Important Changes
CloudNativePG is moving toward a plugin-based, backup and recovery agnostic architecture (initiated in 1.26.0 with Barman Cloud). As part of this transition, the following fields in the
.statussection of theClusterresource are now deprecated:firstRecoverabilityPointfirstRecoverabilityPointByMethodlastSuccessfulBackuplastSuccessfulBackupByMethodlastFailedBackupAdditionally, the following Prometheus metrics are deprecated:
cnpg_collector_first_recoverability_pointcnpg_collector_last_available_backup_timestampcnpg_collector_last_failed_backup_timestampThese fields and metrics will no longer update when using plugin-based backups (e.g., Barman Cloud via CNPG-I). They remain functional for users still using in-core Barman Cloud and volume snapshot backups.
Changes
386and ARM (v5/v6/v7) architectures from thecnpgplugin build matrix, reducing the number of published binaries (#7648).Enhancements
Improved validation of
shared_buffersby correctly consideringHugePagessettings, ensuring accurate memory configuration checks (#7864).Set
oom_score_adjfor PostgreSQL worker processes to improve prioritization during out-of-memory situations (#7891).Added
fqdn-uriandfqdn-jdbc-urifields in user secrets to simplify application connection string management and align with DNS-based connection best practices (#7852).Added the
systemIDfield and related condition in theClusterstatus to track the PostgreSQL system identifier. (#7717).Fixes
Added a mutex in the connection pooler to protect concurrent access to the connections map, improving stability in high-concurrency environments (#7804).
Fixed replica cluster instance ordering by correctly detecting the designated primary, improving replica cluster stability and switchover operations (#8108).
Added support for reconciling
VolumeAttributesClassfor PVCs, enhancing storage compatibility and lifecycle management (#7885).Made the internal webserver routines non-blocking to improve responsiveness under load (#8071).
Fixed an issue where the
ensureReplicationClientLeafCertificateerror did not display the correctsecretNamein the not found message (#8086).Prevented invalid
ALTER SUBSCRIPTIONstatements by updating only PostgreSQL‑supported parameters; unsupported options likecopy_dataare ignored to avoid reconciliation failures (7844).Fixed an issue where the
bootstrap-controllerin the connection pooler did not applyresourcessettings correctly (#7922).Ensured online backups fail cleanly if the
targetPodbecomes unhealthy during backup, preventing partial or misleading backups (#7944).Ensured the Backup resource status is set properly after a failure, improving observability and scripting reliability (#7898).
Improved liveness probe handling to avoid unnecessary timeouts when they are not required (#7902).
v1.26.0Compare Source
Release date: May 23, 2025
Important Changes
CloudNativePG is now officially a CNCF project: CloudNativePG has been accepted into the Cloud Native Computing Foundation (CNCF), marking a significant milestone in its evolution. As part of this transition, the project is now governed under CloudNativePG, a Series of LF Projects, LLC, ensuring long-term sustainability and community-driven innovation. (#7203)
Deprecation of Native Barman Cloud Support: Native support for Barman Cloud backups and recovery is now deprecated and will be fully removed in CloudNativePG version 1.28.0. Although still available in the current release, users are strongly encouraged to begin migrating their existing clusters to the new Barman Cloud Plugin to ensure a smooth and seamless transition. The plugin should also be used for all new deployments. This change marks the first step toward making CloudNativePG a backup-agnostic solution, a goal that will be fully realized when volume snapshot support is also moved to a plugin-based architecture. (#6876)
End of Support for Barman 3.4 and Earlier: CloudNativePG no longer supports Barman versions 3.4 and earlier, including the capability detection framework. Users running older operand versions (from before April 2023) must update their operand before upgrading the operator to avoid compatibility issues. (#7220)
Hibernation Command Changes: The
hibernate onandhibernate offcommands in thecnpgplugin forkubectlnow serve as shortcuts for declarative hibernation. The previous imperative approach has been removed in favor of this method. Additionally, thehibernate statuscommand has been removed, as its functionality is now covered by the standardstatuscommand. Warning: Do not upgrade to version 1.26 of both the plugin and the operator unless you are prepared to migrate to the declarative hibernation method. (#7155)Features
Declarative Offline In-Place Major Upgrades of PostgreSQL: Introduced support for offline in-place major upgrades when a new operand container image with a higher PostgreSQL major version is applied to a cluster. During the upgrade, all cluster pods are shut down to ensure data consistency. A new job is created to validate upgrade conditions, run
pg_upgrade, and set up new directories forPGDATA, WAL files, and tablespaces as needed. Once the upgrade is complete, replicas are re-created. Failed upgrades can be rolled back declaratively. (#6664)Improved Startup and Readiness Probes for Replicas: Enhanced support for Kubernetes startup and readiness probes in PostgreSQL instances, providing greater control over replicas based on the streaming lag. (#6623)
Declarative management of extensions and schemas: Introduced the
extensionsandschemasstanzas in the Database resource to declaratively create, modify, and drop PostgreSQL extensions and schemas within a database. (#7062)Enhancements
Introduced an opt-in experimental feature to enhance the liveness probe with network isolation detection for primary instances. This feature can be activated via the
alpha.cnpg.io/livenessPingerannotation (#7466).Introduced the
STANDBY_TCP_USER_TIMEOUToperator configuration setting, allowing users to specify thetcp_user_timeoutparameter on all standby instances managed by the operator. (#7036)Introduced the
DRAIN_TAINTSoperator configuration option, enabling users to customize which node taints indicate a node is being drained. This replaces the previous fixed behavior of only recognizingnode.kubernetes.io/unschedulableas a drain signal. (#6928)Added a new field in the
statusof theClusterresource to track the latest known Pod IP (#7546).Added the
pg_extensionsmetric, providing information about installed PostgreSQL extensions and their latest available versions. (#7195)Added the
KUBERNETES_CLUSTER_DOMAINconfiguration option to the operator, allowing users to specify the domain suffix for fully qualified domain names (FQDNs) generated within the Kubernetes cluster. If not set, it defaults tocluster.local. (#6989)Implemented the
cnpg.io/validationannotation, enabling users to disable the validation webhook on CloudNativePG-managed resources. Use with caution, as this allows unrestricted changes. (#7196)Added support for patching PostgreSQL instance pods using the
cnpg.io/podPatchannotation with a JSON Patch. This may introduce discrepancies between the operator’s expectations and Kubernetes behavior, so it should be used with caution. (#6323)Added support for collecting
pg_stat_walmetrics in PostgreSQL 18. (#7005)Removed the
ENABLE_AZURE_PVC_UPDATESconfiguration, as it is no longer required to resize Azure volumes correctly. The Azure CSI driver includes the necessary fix as of version 1.11.0. (#7297)The
.spec.backup.barmanObjectStoreand.spec.backup.retentionPolicyfields are now deprecated in favor of the external Barman Cloud Plugin, and a warning is now emitted by the admission webhook when these fields are used in theClusterspecification (#7500).Added support for LZ4, XZ, and Zstandard compression methods when archiving WAL files via Barman Cloud (deprecated). (#7151)
CloudNativePG Interface (CNPG-I):
A plugin can now trigger instance rollouts by implementing the
EVALUATEverb, ensuring that plugin-induced changes are properly reconciled. (#7126)Introduced support for WAL recovery via CNPG-I plugins during snapshot restore. (#7284)
Security
imagePullPolicytoAlwaysfor the operator deployment to ensure that images are always pulled from the registry, reducing the risk of using outdated or potentially unsafe local images. (#7250)Fixes
Fixed native replication slot synchronization and logical replication failover for PostgreSQL 17 by appending the
dbnameparameter toprimary_conninfoin replica configurations (#7298).Fixed a regression in WAL restore operations that prevented fallback to the in-tree
barmanObjectStoreconfiguration defined in theexternalClustersource when a plugin failed to locate a WAL file (#7507).Improved backup efficiency by introducing a fail-fast mechanism in WAL archiving, allowing quicker detection of unexpected primary demotion and avoiding unnecessary retries (#7483).
Fixed an off-by-one error in parallel WAL archiving that could cause one extra worker process to be spawned beyond the requested number (#7389).
Resolved a race condition that caused the operator to perform two switchovers when updating the PostgreSQL configuration. (#6991)
Corrected the
PodMonitorconfiguration by adjusting thematchLabelsscope for the targeted pooler and cluster pods. Previously, thematchLabelswere too broad, inadvertently inheriting labels from the cluster and leading to data collection from unintended targets. (#7063)Added a webhook warning for clusters with a missing unit (e.g., MB, GB) in the
shared_buffersconfiguration. This will become an error in future releases. Users should update their configurations to include explicit units (e.g.,512MBinstead of512). (#7160)Treated timeout errors during volume snapshot creation as retryable to prevent unnecessary backup failures. (#7010)
Moved the defaulting logic for
.spec.postgresql.synchronous.dataDurabilityfrom the CRD to the webhook to avoid UI issues with OLM. (#7600)CloudNativePG Interface (CNPG-I):
Implemented automatic reloading of TLS certificates for plugins when they change. (#7029)
Ensured the operator properly closes the plugin connection when performing a backup using the plugin. (#7095, #7096)
Fixed an issue that prevented WALs from being archived on a former primary node when using a plugin. (#6964)
Improved performance and resilience of CNPG-I by removing timeouts for local plugin operations, avoiding failures during longer backup or WAL archiving executions (#7496).
cnpgplugin:Increased the buffer size in the
logs prettycommand to better handle larger log output (#7281).Ensured the
plugin-nameparameter is required for plugin-based backups and disallowed for non-plugin backup methods (#7506).Ensured that the primary Pod is recreated during an imperative restart when
primaryUpdateMethodis set torestart, aligning its definition with the replicas. (#7122)Changes
Updated the default PostgreSQL version to 17.5 for new cluster definitions. (#7556)
Updated the default PgBouncer version to 1.24.1 for new
Poolerdeployments (#7399).Supported versions
v1.25.4Compare Source
Release date: Oct 23, 2025
!!! Warning This is the final release in the 1.25.x series. Users are strongly encouraged to upgrade to a newer minor version, as 1.25 is no longer supported.
Changes
Adopted the new format of
postgres-containersandpostgis-containersimages and image catalog artifacts, and updated the default PostgreSQL version to18.0-system-trixie(PostgreSQL 18 is now supported). (#8578, #8760, #8558)Deprecated the
monitoring.enablePodMonitorfield in theClusterandPoolerresources. This field will beConfiguration
📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).
🚦 Automerge: Enabled.
♻ Rebasing: Whenever PR is behind base branch, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
This PR was generated by Mend Renovate. View the repository job log.