-
Notifications
You must be signed in to change notification settings - Fork 529
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
Support for multiple platforms in jib build strategy #2098
Comments
Hello @manusa @rohanKanojia , I'm ready to make this improvement, but I need your help. I see here 2 options for how we can do it:
Another problem is that docker does not support multiple platforms without a manifest, so for a normal docker build, we will most likely have to limit the number of platforms to one |
Another thing I observed is that JIB multi-platform mode doesn't support generating local tar (what our |
In order to keep things simple and to keep backwards compatibility, how would adding a This should allow to provide an XML configuration as: <image>
<name>final/image:version</name>
<build>
<from>base/image:version</from>
<fromPlatforms>
<platform>
<architecture>amd64</architecture>
<os>linux</os>
</platform>
<platform>
<architecture>arm64</architecture>
<os>linux</os>
</platform>
</fromPlatforms>
</build>
<image>
We need to find out how to overcome this. Maybe JIB supports generating multiple tarballs, but requires additional config.
If the previous issue with JIB can't be overcome, then we might need to limit platforms to one regardless of the build mechanism and suggest users to use Maven profiles or properties. |
@manusa JIB supports multiple architectures only for registry builds, tar and docker builds do not support multi-arch builds. We can add registry build support, but k8s:build will push images to the registry after the build. At the same time, we will also need to update k8s:push to also support the registry build. Docker also does not support multi-arch builds by itself, to support it we will also need to generate a manifest file and push images and the manifest. There is also a buildx command in the docker, but it is not present in API, so we are unlikely to be able to use it. |
I'll try to create a PoC to support this. |
Component
Kubernetes Maven Plugin
Is your enhancement related to a problem? Please describe
We are experimenting with maven plugins providing JIB in the Apache Camel-k project. We really like the results from our tests with the current JKube Kubernetes Maven Plugin (with
-Djkube.build.strategy=jib
), but it lacks the support for multiple platform we want to introduce as a part of the new feature that is JIB for our project.Describe the solution you'd like
Our goal is to be able to build the container image using JIB a list of platform architectures (linux/am64, linux/arm64, etc).
The ideal solution would be to provide some configuration defining the platforms we want to build images for like this one or anything else that fits more the way the configuration is done in the Kubernetes Maven Plugin or Openshift Maven Plugin.
From previous discussion, the change would be in the JKube Kit and as such could be used in either the Kubernetes Maven Plugin and the Openshift Maven plugin.
Describe alternatives you've considered
I have considered using the other plugins tools for my features : Quarkus Container Extension Jib, Google's Jib Maven Plugin, Fabric8 Docker Plugin. While the Google's Jib Maven Plugin might works for our use case, we find the JKube plugins to be a better choice for the future and would like to use it.
Additional context
There is already some discussion in this issue #1876 .
It was suggested that the change could be:
setPlatform
method being available in Jib.from method call here: https://github.com/eclipse/jkube/blob/e573db610e21284a52782e84faeaaf68fe1c4eb7/jkube-kit/build/service/jib/src/main/java/org/eclipse/jkube/kit/service/jib/JibServiceUtil.java#L120I was unsure of the right component to declare, so I used what is my first requirement, but it should probably be changes in JKube Kit and Kubernetes Maven Plugin and Openshift Maven Plugin.
The text was updated successfully, but these errors were encountered: