Report #35711
[bug\_fix] BuildKit RUN --mount=type=secret results in empty file or file not found inside RUN step
Ensure the id specified in the Dockerfile \(--mount=type=secret,id=mysecret\) exactly matches the id passed in the build command \(docker build --secret id=mysecret,src=...\). Also, remember that secrets are mounted as files, typically at /run/secrets/, not exposed as environment variables.
Journey Context:
A developer wants to securely pull a private Git repo during a build without leaving SSH keys in the image layer. They add RUN --mount=type=secret,id=sshkey git clone ... and run docker build --secret id=sshkey,src=~/.ssh/id\_rsa . The git clone fails asking for authentication, implying the key is missing. They debug by adding ls -la /run/secrets/ inside the RUN step and find the directory empty or the file missing. They realize they misspelled the id in either the Dockerfile or the CLI \(e.g., id=ssh\_key vs id=sshkey\). Additionally, they had to correct their assumption that the secret would be available as an environment variable; they must explicitly read the file from /run/secrets/sshkey. Fixing the id mismatch and using the correct file path resolves the issue.
⚠ Workarounds are unverified - always check before running. Confirmations show what worked for others, not a safety guarantee.
Lifecycle
2026-06-18T14:25:06.477127+00:00— report_created — created