apiVersion: batch/v1 kind: Job metadata: name: buildkit spec: template: metadata: annotations: container.apparmor.security.beta.kubernetes.io/buildkit: unconfined container.seccomp.security.alpha.kubernetes.io/buildkit: unconfined # see buildkit/docs/rootless.md for caveats of rootless mode spec: restartPolicy: Never initContainers: - name: prepare image: alpine:3.10 command: - sh - -c - "echo FROM hello-world > /workspace/Dockerfile" securityContext: runAsUser: 1000 runAsGroup: 1000 volumeMounts: - name: workspace mountPath: /workspace containers: - name: buildkit image: moby/buildkit:master-rootless env: - name: BUILDKITD_FLAGS value: --oci-worker-no-process-sandbox command: - buildctl-daemonless.sh args: - build - --frontend - dockerfile.v0 - --local - context=/workspace - --local - dockerfile=/workspace # To push the image to a registry, add # `--output type=image,name=docker.io/username/image,push=true` securityContext: # To change UID/GID, you need to rebuild the image runAsUser: 1000 runAsGroup: 1000 volumeMounts: - name: workspace readOnly: true mountPath: /workspace # To push the image, you also need to create `~/.docker/config.json` secret # and set $DOCKER_CONFIG to `/path/to/.docker` directory. volumes: - name: workspace emptyDir: {}