php 8.3
Runtime · Language runtime · standard · v8.3
Hardened PHP cli + common extensions. Latest 3 stable (8.3/8.4/8.5).
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/php:8.3 Or pull it directly
docker pull ghcr.io/quenchworks/images/php:8.3 - Version line
- 8.3
- Latest line
- 8.3, 8.4, 8.5
- Architectures
- amd64, arm64
- Runs as
- nonroot (uid 1001)
- Root filesystem
- read-only
- License
- PHP-3.01
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/php:8.3 \
--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/php:8.3 --owner quenchworks
# 3. SPDX SBOM — the package inventory
gh attestation verify oci://ghcr.io/quenchworks/images/php:8.3 --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.3
Resolve dependencies with Composer in the build stage, then copy the vendor tree and app onto a clean php base. Composer itself never ships in the runtime image.
# Build stage: install prod dependencies with Composer.FROM ghcr.io/quenchworks/images/composer:2 AS buildUSER rootWORKDIR /appENV COMPOSER_CACHE_DIR=/tmp/composer
COPY composer.json composer.lock ./RUN ["composer", "install", "--no-dev", "--no-scripts", "--prefer-dist", "--no-progress"]COPY . .RUN ["composer", "dump-autoload", "--optimize", "--no-dev"]
# Runtime stage: copy vendor + app onto a clean php base, run nonroot.FROM ghcr.io/quenchworks/images/php:8.3 AS runtimeWORKDIR /appCOPY --from=build /app /appUSER 1001EXPOSE 8080CMD ["php", "-S", "0.0.0.0:8080", "-t", "public"]This Dockerfile is pinned to the 8.3 line. For the line-by-line walkthrough and ecosystem variants (npm/Yarn, pip/uv/Poetry, Maven/Gradle), see the Build hardened images guide.
Upstream project: https://github.com/php/php-src