dotnet-runtime 8
Runtime · Runtime base · standard · v8
Hardened .NET runtime for console and worker apps, no SDK. Build on the dotnet image, run here. Lines 8/9/10.
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.
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/dotnet-runtime:8 Or pull it directly
docker pull ghcr.io/quenchworks/images/dotnet-runtime:8 - Version line
- 8
- Latest line
- 8, 9, 10
- 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/dotnet-runtime:8 \
--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/dotnet-runtime:8 --owner quenchworks
# 3. SPDX SBOM — the package inventory
gh attestation verify oci://ghcr.io/quenchworks/images/dotnet-runtime:8 --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 8
dotnet-runtime is a runtime base you copy a published console or worker app onto, not something you build in. Here dotnet publish runs in an SDK build stage and the dotnet-runtime image is the final stage that runs it.
# Build stage: restore and publish the worker/console app with the SDK.FROM ghcr.io/quenchworks/images/dotnet:8 AS buildUSER rootWORKDIR /srcENV NUGET_PACKAGES=/tmp/nuget \ DOTNET_CLI_TELEMETRY_OPTOUT=1
COPY ["Worker.csproj", "./"]RUN ["dotnet", "restore", "Worker.csproj"]COPY . .RUN ["dotnet", "publish", "Worker.csproj", "-c", "Release", "-o", "/app/publish", "--no-restore"]
# This image is the final runtime stage: the plain .NET runtime, nonroot.FROM ghcr.io/quenchworks/images/dotnet-runtime:8 AS runtimeWORKDIR /appCOPY --from=build /app/publish ./USER 1001ENTRYPOINT ["dotnet", "Worker.dll"]This Dockerfile is pinned to the 8 line. For the line-by-line walkthrough and ecosystem variants (npm/Yarn, pip/uv/Poetry, Maven/Gradle), see the Build a .NET app guide.
Upstream project: https://github.com/dotnet/runtime