Using the Chainguard Images Directory

A walkthrough of the Chainguard Images directory.

There are hundreds of Chainguard Images available for use. To help users explore and better understand all of these Images, we’ve developed the Chainguard Images Directory. This guide serves as a walkthrough of the Directory, including how to access it and get the most out of its features.

Accessing the Images Directory

This guide is primarily framed around the Public Images Directory found in the Chainguard Console. The Console is accessible to anyone, including users who aren’t Chainguard customers. To access the Console, you’ll first need to create an account and sign in.

If you’re not ready to create a Chainguard account, you can also follow along with the public Chainguard Images Directory. As of this writing, there are some differences between the two directories, but both should provide a similar experience for users.

The Images Directory

After signing in to the Chainguard Console, your browser will take you to a landing page like the following.

Screenshot showing the Chainguard Console’s Overview page.

Click Public Images in the left-hand navigation to be taken to the Public Images Directory. There, you’ll be presented with a list of all of Chainguard’s Developer Images.

Screenshot of the public Images directory in the Console, showing the tabular view. The table is sorted by the “Updated” column in ascending order, meaning that the most recently updated Images are shown first.

Note: If you are part of an organization, you may have access to resources in the Organization images tab. If so, you explore the images there as you would with the Public Images Directory.

You can toggle between a table view and a card-based view by clicking the buttons to the upper right of the Images directory.

Screenshot of the public Images directory in the Console showing the card view. The toggle buttons that switch between the card view and the table view are highlighted in a yellow box.

Let’s continue using the tabular view for now, as this contains some more information than the card view.

The table view has five columns:

  • Name: the name of each given Image.
  • Latest version: the latest available version of the Image. Note that this column’s value could be a version number or it may read latest. In the former case, this means that the latest version Chainguard offers is a different, later version than the one the publicly available Image tagged with :latest.
  • URI: the registry URI you can use in a docker pull command to download the Image. Production Images, which are not publicly available, will instead have a message reading “Contact us for access to this image” with a link to Chainguard’s contact form.
  • Available versions: a list of what versions are available for this Image. Each Image will have a latest version, and most will also have a latest-dev version.
  • Updated: how long it’s been since the Image was last updated.

Note that Images listed in the Organization Images tab have an extra column labeled Entitlement. This column specifies what resources an organization has purchased and has access to. This column can show one of two possible values: Active, meaning that your organization is able to download and use the Image, or Expired, meaning that your organization had access to the Image in the past but not anymore.

Screenshot showing a portion of an Organization Images directory, including the “Entitlement” tab. This example shows three images: python, node, and mongodb.

You can click on any of these column names to sort the list of Images in ascending or descending order based on the values in these columns.

Above the table is a search box you can use to find specific Images by their name or latest version number. To the right of this box is a drop-down menu labeled Category. You can use this to filter the Images listed based on what category they belong to.

Image information

Next, let’s inspect an individual Image. Click on any Image you’d like. This example shows the page for the ruby Image.

Screenshot of the Image Details page for the ruby Image, showing the “Versions” tab.

Each Image page has seven tabs that provide information about various facets of the given Image.

Versions Tab

The default page for each Image is the Versions tab which contains information about the versions available for each Image. This contains a table with columns:

  • Version: this column lists each version tag available for the Image.
  • Pull URL: the URL you can use to download each version of the Image. As with the main Images Directory page, Production Images will have a message reading “Contact us for access to this image” with a link to Chainguard’s contact form.
  • Size: the size of the Image, in megabytes.
  • Last changed: when each version of the Image was last updated.

Above the table is a search box which you can use to filter the different versions available for the Image. There is also a Category box you can use to filter out Production or Developer Images.

Overview Tab

The Overview tab contains the Image’s README. Typically, this will include instructions on how to download the Image, any relevant compatibility notes, and instructions on how to get started with using the Image.

Provenance Tab

All Chainguard Images contain verifiable signatures and high-quality software bills of materials (SBOMs). These features allow you to confirm the origin of each Image and provide you with a detailed list of everything included in the Image.

The Provenance tab outlines how you can verify Image Signatures and download and verify Image Attestations, all with examples using cosign.

Specifications Tab

The Specifications tab is where you can find a number of important details about a given Image, such as whether the Image ships with the apk package manager or a shell. It also includes information like the Image’s default user ID, environment variables, and its entrypoint.

Screenshot showing the “Specification” tab for the ruby image.

SBOM Tab

The SBOM tab contains a list of packages in the Image. Chainguard Images are built so that everything contained in the Image is a package, meaning that this package list gives a complete view of what’s in the Image. You won’t find anything hidden in the Image that isn’t listed in its SBOM tab.

Screenshot of the ruby Image’s “SBOM” tab, showing two rows of the latest-dev version’s SBOM.

The table listing an Image’s packages has four columns.

  • Package: the name of each package included in the Image’s SBOM.
  • Version: the version of the listed package.
  • Repository: every package found in Chainguard Images is either built and managed by the Chainguard team or sourced from Wolfi. For packages falling into the latter category, this column will include a link to the Wolfi GitHub repository showing the package source.
  • License: the license under which each package is published.

Above the table is a search box you can use to find and filter the packages listed. To the left of this search box is a drop-down menu you can use to select which version of the Image you want to find the SBOM for. By default, this will show the :latest tag.

Finally, to the right of the search box is a button labeled with the Image’s name, the tag selected with the drop-down menu, followed by spdx.json. You can click this button to download the SBOM (in the SPDX format) to your machine.

Note that Chainguard began generating SBOMs for its Images on November 15, 2023. For this reason, any versions of a given Image that were released before that date will not have any SBOM data to show.

Vulnerabilities Tab

The Vulnerabilities tab contains a list of every CVE one can find within the Image.

As with the SBOMs tab, the Vulnerabilities tab has a search box you can use to find and filter specific vulnerabilities within the Image. There is also a drop-down menu to the left allowing you to select different versions of the Image.

Below these is a table listing the vulnerabilities. However, most Chainguard Images won’t show any vulnerabilities for the latest version. This isn’t an error, as we aim to remove vulnerabilities from Images as soon as they arise.

To illustrate how this table appears when vulnerabilities are actually present, you can select different versions in the drop-down until you find one with a vulnerability. This example shows the latest version of the ruby Image.

Screenshot of the ruby Image’s “Vulnerabilities” tab, with “latest” selected in the version drop-down menu. The table shows two vulnerabilities: “CVE-2024-41946” and “CVE-2024-41123”, both with a “Medium” severity. These CVEs are associated with version 3.3.2 of the “rexml” package.

The Vulnerabilities table has five columns.

  • CVE ID: the official identification number of each vulnerability present in the table.
  • Severity: the severity of each given vulnerability. This can either read Critical, High, Medium, Low, or Unknown
  • Package: showing the package where the vulnerability was found
  • Version: the version of the package containing the vulnerability
  • Last detected: the date and time when the vulnerability last appeared in a scan of the Image

To the left of each row in the table is down-pointing chevron (˅). If you click on this symbol, more information about the given vulnerability will appear below the vulnerability’s row.

Screenshot showing the expanded view of the “CVE-2024-41946” vulnerability. This expanded view includes a brief description of the CVE as well as some reference links.

Specifically, this will highlight the Package name and Version number of the package associated with the Vulnerability. It also shows the Fixed version of the package, a brief Description of the vulnerability, and one or more References you can review to learn more about the vulnerability.

Please be aware that, as with SBOM data, Chainguard began generating vulnerability information for its Images on November 15, 2023. For this reason, any versions of a given Image that were released before that date will not have any vulnerability data to show.

Advisories tab

The last tab is the Advisories tab. When you scan a newly-built Chainguard Image with a vulnerability scanner, typically, no CVEs will be reported. However, as software packages age, more vulnerabilities are reported and CVEs will begin to accumulate in images. When this happens, Chainguard releases security advisories to communicate these vulnerabilities to downstream Images users. You can find all the advisories issued for a given Image in its Advisories tab.

To learn more about Chainguard security advisories, we encourage you to read our article on How Chainguard Issues Security Advisories as well as our guide on How to Use Chainguard Security Advisories. You an also find every security advisory published for Chainguard Images by exploring our self-service Security Advisories page/

Learn More

The Chainguard Images Directory is a useful tool for understanding what Chainguard Images are available. To better understand how to work with individual Images, you can see if we have a getting started guide available. We also provide a guide on how to view security advisories through our self-service public Security Advisories page.

Last updated: 2024-08-05 11:07