Quenchworks

node 22

Runtime · Language runtime · standard · v22

0 fixable CVEs nonroot cosign signed SPDX SBOM SLSA provenance amd64 · arm64

Hardened Node.js runtime + npm. Active LTS lines (20/22/24).

Version line

The latest line lives at the base page; older lines have their own page so you can pin and verify exactly that version.

Image
ghcr.io/quenchworks/images/node:22
Signed
cosign keyless
SBOM
SPDX, on digest
Provenance
SLSA build
Architectures
amd64, arm64
Runs as
nonroot (uid 1001)
Image size
58.0 MB
SBOM packages
185
Last rebuilt
2026-06-12

Use it as a base image

Reference it in the FROM line of your Dockerfile. Nonroot, read-only root filesystem, built for amd64 and arm64.

FROM ghcr.io/quenchworks/images/node:22

Or pull it directly

docker pull ghcr.io/quenchworks/images/node:22
Version line
22
Latest line
20, 22, 24
Architectures
amd64, arm64
Runs as
nonroot (uid 1001)
Root filesystem
read-only
License
MIT

Verify the supply chain

This image is cosign-signed and carries an SPDX SBOM and a SLSA build-provenance attestation on the same digest. Check all three before you build on it:

# 1. signature — built and signed by QuenchWorks CI
cosign verify ghcr.io/quenchworks/images/node:22 \
  --certificate-identity-regexp 'https://github.com/quenchworks/.+' \
  --certificate-oidc-issuer https://token.actions.githubusercontent.com

# 2. SLSA build provenance — which workflow built it, from what
gh attestation verify oci://ghcr.io/quenchworks/images/node:22 --owner quenchworks

# 3. SPDX SBOM — the package inventory
gh attestation verify oci://ghcr.io/quenchworks/images/node:22 --owner quenchworks \
  --predicate-type https://spdx.dev/Document

See the SBOM & provenance guide for reading the SBOM and using these checks in CI.

Best-practice Dockerfile for 22

The four-stage pnpm pattern: a shared base, a prod-only dependency stage, a build stage with the full dependency set, and a slim final stage that ships only the production node_modules and the built dist.

ghcr.io/quenchworks/images/node:22 58.0 MB rebuilt 3 days ago 185 SBOM pkgs
# Base: a common starting point for the dependency and build stages.
FROM ghcr.io/quenchworks/images/node:22 AS base
WORKDIR /app
ENV PNPM_HOME=/tmp/pnpm \
npm_config_cache=/tmp/npm
# prod-deps: resolve production dependencies only.
FROM base AS prod-deps
COPY package.json pnpm-lock.yaml ./
RUN ["corepack", "enable"]
RUN ["pnpm", "install", "--prod", "--frozen-lockfile"]
# build: install the full dependency set and build.
FROM base AS build
COPY package.json pnpm-lock.yaml ./
RUN ["corepack", "enable"]
RUN ["pnpm", "install", "--frozen-lockfile"]
COPY . .
RUN ["pnpm", "run", "build"]
# final: prod node_modules + built dist on a clean node base, nonroot.
FROM ghcr.io/quenchworks/images/node:22 AS final
WORKDIR /app
ENV NODE_ENV=production
COPY --from=prod-deps /app/node_modules ./node_modules
COPY --from=build /app/dist ./dist
COPY --from=build /app/package.json ./package.json
USER 1001
EXPOSE 3000
CMD ["node", "dist/server.js"]

This Dockerfile is pinned to the 22 line. For the line-by-line walkthrough and ecosystem variants (npm/Yarn, pip/uv/Poetry, Maven/Gradle), see the Build a Node app guide.

Upstream project: https://github.com/nodejs/node