IMPORTANT: Starting in August 2025, the Official Postgres Image, maintained by the PostgreSQL Docker Community, has discontinued support for Debian
bullseye
. In response, the CloudNativePG project has completed the transition to the newbake
-based build process for allsystem
images. We now build directly on top of the official Debian slim images, fully detaching from the official Postgres image.
This repository provides maintenance scripts for generating immutable application containers for all supported PostgreSQL major versions:
Version | Release Date | EOL |
---|---|---|
17 | 2024-09-26 | 2029-11-08 |
16 | 2023-09-14 | 2028-11-09 |
15 | 2022-10-13 | 2027-11-11 |
14 | 2021-09-30 | 2026-11-12 |
13 | 2020-09-24 | 2025-11-13 |
In addition, PostgreSQL 18 RC1 is provided for testing purposes only.
These images are designed to serve as operands of the CloudNativePG (CNPG) operator in Kubernetes environments, and are not intended for standalone use.
CloudNativePG PostgreSQL container images:
- Are built on top of Debian Linux (
stable
andoldstable
). - Provide multi-architecture support, including
linux/amd64
andlinux/arm64
. - Ship with build attestations, such as Software Bills of Materials (SBOMs) and provenance metadata.
- Are published in the CloudNativePG GitHub Container Registry.
- Are automatically rebuilt every week (on Mondays) to remain up to date with the latest upstream security and bug fixes.
CloudNativePG PostgreSQL container images are based on the official stable
and oldstable
Debian releases, maintained and supported by the
Debian Project.
The table below summarises the support lifecycle of relevant Debian versions, including End-of-Life (EOL) and Long-Term Support (LTS) dates.
Name | Version | Release Date | EOL | LTS | Status |
---|---|---|---|---|---|
Trixie (stable ) |
13 | 2025-08-09 | 2028-08-09 | 2030-06-30 | Supported |
Bookworm (oldstable ) |
12 | 2023-06-10 | 2026-06-10 | 2028-06-30 | Supported |
Bullseye (oldoldstable ) |
11 | 2021-08-14 | 2024-08-14 | 2026-08-31 | Deprecated |
IMPORTANT: The CloudNativePG project provides full support for Debian-based images until each release reaches its official End-of-Life (EOL). After EOL and until the start of Long-Term Support (LTS), images for the deprecated releases, such as
oldoldstable
, are maintained on a best-effort basis. If discontinuation becomes necessary before the LTS date, a minimum three-month advance notice will be posted on this page.
We currently provide and maintain three main types of PostgreSQL images:
Both minimal
and standard
images are designed to work with backup plugins
such as Barman Cloud.
The system
images, built on top of the standard
ones, also include the
Barman Cloud binaries.
Minimal images are lightweight and built on top of the official Debian images. They use the APT PostgreSQL packages maintained by the PostgreSQL Global Development Group (PGDG).
These images are identified by the inclusion of minimal
in their tag names,
for example: 17.6-minimal-trixie
.
NOTE: Starting with PostgreSQL 18,
minimal
images will not include LLVM JIT support (shipped in thepostgresql-MM-jit
package, whereMM
represents the PostgreSQL major version). JIT will be available only in thestandard
image.
Standard images are an extension of the minimal
images, enhanced with the
following additional features:
- PGAudit
- Postgres Failover Slots
- pgvector
- All Locales
- LLVM JIT support
- For PostgreSQL 17 and earlier: included in the main PostgreSQL packages,
also available in
minimal
images - From PostgreSQL 18 onwards: provided by the separate
postgresql-MM-jit
package
- For PostgreSQL 17 and earlier: included in the main PostgreSQL packages,
also available in
Standard images are identifiable by the standard
tag in their names, such as:
17.6-standard-trixie
.
Note: Standard images are designed to offer functionality equivalent to the legacy
system
images when used with CloudNativePG. To achieve parity, you must use the Barman Cloud Plugin as a replacement for the native Barman Cloud support insystem
images.
Starting from September 2025, system images are based on the standard
image
and include Barman Cloud binaries.
IMPORTANT: The
system
images are deprecated and will be removed once in-core support for Barman Cloud in CloudNativePG is phased out. While you can still use them as long as in-core Barman Cloud remains available, you should plan to migrate to either aminimal
orstandard
image together with the Barman Cloud plugin—or adopt another supported backup solution.
Each image is identified by its digest and a main tag of the form:
MM.mm-TS-TYPE-OS
where:
MM
is the PostgreSQL major version (e.g.16
)mm
is the PostgreSQL minor version (e.g.10
)TS
is the build timestamp with minute precision (e.g.202509090953
)TYPE
is image type (e.g.minimal
)OS
is the underlying distribution (e.g.trixie
)
For example: 16.10-202509090953-minimal-trixie
.
In addition to fully qualified tags, rolling tags are available in the following formats:
MM.mm-TYPE-OS
: latest image for a given PostgreSQL minor version (16.10
) of a specific type (minimal
) on a Debian version (trixie
). For example:16.10-minimal-trixie
.MM-TYPE-OS
: latest image for a given PostgreSQL major version (16
) of a specific type (minimal
) on a Debian version (trixie
). For example:16-minimal-trixie
.
While the most reliable way to reference an image is by its digest, the
MM.mm-TYPE-OS
tag usually provides a good balance between stability and
convenience for most use cases.
For historical reasons, the system
image also carries two additional rolling
tags:
MM.mm
: latestsystem
image for a given PostgreSQL minor version (e.g.16.10
) on Debianbullseye
.MM
: latestsystem
image for a given PostgreSQL major version (e.g.16
) on Debianbullseye
.
IMPORTANT: These tags are deprecated and will be removed when
bullseye
images reach end of life. Please migrate to one of the supported
tag formats that explicitly include both the image type and the
distribution version (e.g. 16.10-minimal-trixie
).
CloudNativePG publishes ClusterImageCatalog
manifests for CloudNativePG in
the artifacts
repository,
with one catalog available for each supported combination of image type and
operating system version.
IMPORTANT: If you are still relying on the legacy
ClusterImageCatalog-bullseye.yaml
and ClusterImageCatalog-bookworm.yaml
manifests, please migrate to the new catalogs as soon as possible. These legacy
manifests are deprecated and will be removed along with the system
image.
CNPG PostgreSQL Container Images are built with the following attestations to ensure transparency and traceability:
-
Software Bill of Materials (SBOM): A comprehensive list of software artifacts included in the image or used during its build process, formatted using the in-toto SPDX predicate standard.
-
Provenance: Metadata detailing how the image was built, following the SLSA Provenance framework.
For example, you can retrieve the SBOM for a specific image using the following command:
docker buildx imagetools inspect <IMAGE> --format "{{ json .SBOM.SPDX }}"
This command outputs the SBOM in JSON format, providing a detailed view of the software components and build dependencies.
The minimal
and standard
CloudNativePG container images are securely signed using
cosign, a tool within the
Sigstore ecosystem.
This signing process is automated via GitHub Actions and leverages
short-lived tokens issued through OpenID Connect.
The token issuer is https://token.actions.githubusercontent.com
, and the
signing identity corresponds to a GitHub workflow executed under the
cloudnative-pg/postgres-containers
repository. This workflow uses the
cosign-installer
action
to facilitate the signing process.
To verify the authenticity of an image using its digest, you can run the
following cosign
command:
cosign verify IMAGE \
--certificate-identity-regexp="^https://github.com/cloudnative-pg/postgres-containers/" \
--certificate-oidc-issuer="https://token.actions.githubusercontent.com"
For detailed instructions on building PostgreSQL container images, refer to the BUILD.md file.
This software is available under Apache License 2.0.
Copyright The CloudNativePG Contributors.
Barman Cloud is distributed by EnterpriseDB under the GNU GPL 3 License.
PGAudit is distributed under the PostgreSQL License.
Postgres Failover Slots is distributed by EnterpriseDB under the PostgreSQL License.
pgvector is distributed under the PostgreSQL License.
Postgres, PostgreSQL and the Slonik Logo are trademarks or registered trademarks of the PostgreSQL Community Association of Canada, and used with their permission.