Skip to content
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

Closed
gansheer opened this issue Mar 24, 2023 · 5 comments · Fixed by #3090
Closed

Support for multiple platforms in jib build strategy #2098

gansheer opened this issue Mar 24, 2023 · 5 comments · Fixed by #3090
Assignees
Labels
enhancement New feature or request
Milestone

Comments

@gansheer
Copy link

gansheer commented Mar 24, 2023

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:

I 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.

@pavel1tel
Copy link
Contributor

pavel1tel commented Apr 3, 2023

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:

  1. Add platform support to the <from> field and do it like this
    <from>--platform=windows/amd64 --platform=linux/arm64 openjdk:latest</from>(just parse the string)
  2. Or modify <from> and make it an object like here

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

@rohanKanojia
Copy link
Member

Another thing I observed is that JIB multi-platform mode doesn't support generating local tar (what our k8s:build does in JIB build strategy). Not 100% sure but we might need to change behavior of this goal when multiple platforms are selected.

@manusa
Copy link
Member

manusa commented Apr 4, 2023

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:

  1. Add platform support to the <from> field and do it like this
    <from>--platform=windows/amd64 --platform=linux/arm64 openjdk:latest</from>(just parse the string)
  2. Or modify <from> and make it an object like here

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

In order to keep things simple and to keep backwards compatibility, how would adding a fromPlatforms field to BuildConfiguration loop?

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>

Another thing I observed is that JIB multi-platform mode doesn't support generating local tar

We need to find out how to overcome this. Maybe JIB supports generating multiple tarballs, but requires additional config.
This would also have repercussions for the push phase.

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

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.

@pavel1tel
Copy link
Contributor

@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.

@manusa manusa self-assigned this Dec 13, 2023
@manusa manusa moved this to Planned in Eclipse JKube Dec 13, 2023
@manusa
Copy link
Member

manusa commented Dec 13, 2023

I'll try to create a PoC to support this.
The goal is to have a platforms field that can be used to set the target platforms.
For JIB it should be straightforward.
For Docker we might want to experiment with building each image separately and use docker manifest to merge them. Otherwise, docker buildx should be the way to go, however this won't work from the HTTP API.

@manusa manusa removed their assignment Apr 24, 2024
@manusa manusa self-assigned this May 8, 2024
@manusa manusa moved this from Planned to In Progress in Eclipse JKube May 8, 2024
@manusa manusa added this to the 1.17.0 milestone May 23, 2024 — with automated-tasks
@manusa manusa moved this from In Progress to Review in Eclipse JKube May 23, 2024
@github-project-automation github-project-automation bot moved this from Review to Done in Eclipse JKube May 28, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

Successfully merging a pull request may close this issue.

4 participants