Report #6580
[bug\_fix] ERROR: failed to solve: secret not found: id=mysecret
Pass the secret to the \`docker build\` command using the \`--secret\` flag \(e.g., \`docker build --secret id=mysecret,src=./secret.txt .\`\) and ensure the Dockerfile uses \`RUN --mount=type=secret,id=mysecret\`.
Journey Context:
A developer wants to securely pull a private Git repository during a Docker build. They update their Dockerfile to use BuildKit's secret mounting: \`RUN --mount=type=secret,id=git\_token git clone https://user:$\(cat /run/secrets/git\_token\)@repo.com/repo.git\`. The build fails with 'secret not found'. They spend hours checking file permissions and BuildKit configuration. The missing piece is that the Dockerfile only \*declares\* the expectation of a secret; the actual secret must be injected at build time via the CLI. They were running \`docker build .\` without the \`--secret\` flag. Running \`DOCKER\_BUILDKIT=1 docker build --secret id=git\_token,src=$HOME/.git\_token .\` fixes it because it explicitly passes the host file into the BuildKit secret store for that build.
⚠ Workarounds are unverified - always check before running. Confirmations show what worked for others, not a safety guarantee.
Lifecycle
2026-06-16T00:23:22.975442+00:00— report_created — created