-
Notifications
You must be signed in to change notification settings - Fork 1.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[FR] Multi architecture build with only Kaniko #1746
Comments
About the custom platform, it may or may not work on Intel. It works for you as you have Go code, which can be cross compiled. It would not work in some other use cases. The only difference with dockerx is that you would have 3 images/tag in the repo. arm64, amd64, and the multi (let's say latest) |
I am still confused. Who has a running example with Kaniko multi arch used to build both AMD64 and ARM64 images? Could the Kaniko team please update the doc with such an exemple? |
bump |
We are confused by the docs too. Theoretically, Docker can build multiple platforms with buildx, independent from the host. Does Kaniko use buildx or not? |
For anybody like me finding this thread, I think I got it to work by calling kaniko executor with
Correction: That only works with either pure docker commands, or a native worker for the kaniko executor. Kaniko is not capable of executing non-native code emulated in the way buildx is. But if you have a Kubernetes with nodes of both types, you can build one image on each and manifest it together, so at least then this helps. |
Related: Recently some documentation was added in Kaniko's README.md regarding how to create multi-arch images with Kaniko with the caveat being that this is done by stitching N kaniko runs/images together into a final image (similar to what @autarchprinceps mentions in the comment above). Link here: I will re-title this issue to be around the feature-request to add a way for Kaniko to do this on its own |
Related to this issue, I'm wondering if it's currently even possible to come up with a solution for multi stage builds. Example working using docker build, but that's coming up with exec format error with kaniko running on amd64 host, to build arm64 target (Which I think shouldn't have any trouble, since it shouldn't even run target platform binaries)
My build is also using these generated arguments to try keeping things compatible with docker
So well, just to say, it's currently really tricky to get things done and I would be definitely happy to see a proper solution to build multi arch images, since my environment currently can't host arm64 servers |
Looking at kaniko/pkg/image/image_util.go Lines 90 to 92 in 9c08f1c
it seems that |
In the issue #1474 and #1531 a multi arch support was added by using Docker BuildX and QEMU.
In our team, the main motivation to use kaniko is to get rid of direct docker commands.
Is there any better plan to build multi architecture image WITHOUT any BuildX use?
In our teams, we have pipelines using the plain docker BuildX without Kaniko for one single image name for 2 architectures.
and others using Kaniko to build separate images: one for AMD64, the other for ARM64.
(with e.g. --build-arg opts='GOARCH=arm64' --customPlatform=linux/arm64/v8 to build ARM64 from an Intel runner, as accepted as a solution of the issue #1587 )
btw, the Readme concerning the customPlatform is a bit confusing: it does work for ARM image on Intel runner!
Kaniko with one image for both architecture would be the best of both world.
Any input, suggestion and roadmap would be highly appreciated.
The text was updated successfully, but these errors were encountered: