-
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
Parallel build of multi-stage Docker images #1548
Comments
Hello, We have a build with several build stage (compilation) with a final stage taking all compiled binaries. Looks like this issue could be easily fixed using some goroutine and a simple env/param to define max "worker" to use (like this loop) As this issue got a lot upvote, I could work on it but is it an accepted design or is there a limitation I missed ? |
This would be a great addition. Any news on this ? Thanks in advance |
Hi, I am not an author of the project but am about to fix some standing issues regarding these which should be fixed first: I think "main" still has some weird bugs with stages, most users do not use lots of stages and some problems do not arise (due to hasing etc.) I guess @jason Hall could clarify maybe how to go about this if its even possible, I guess it should be, but is not so trivial as stated above, since your are basically solving a DAG because every stage has a parent. So simply speaking
|
This would speed up our builds tremendously. Honestly an implementation identical to buildkit, where the stages all start and build up to a waiting dependency (if there is one) would be a suitable implementation. |
Could we first build data structure which builds this DAG, then solve an execution order (coloring) and then simply execute it in parallel. Maybe everything in different PRs. Step 3 would then finally enable this :)
Von meinem iPhone gesendet
… Am 06.06.2022 um 08:12 schrieb Christopher Powroznik ***@***.***>:
This would speed up our builds tremendously. Honestly an implementation identical to buildkit, where the stages all start and build up to a waiting dependency (if there is one) would be a suitable implementation.
—
Reply to this email directly, view it on GitHub, or unsubscribe.
You are receiving this because you commented.
|
would be a great feature, saves some time and resources |
We need this please! We have 3 stages with vue build, in docker buildkit they run in parallel, and with kaniko in serial |
bumping this as it would be a nice feature that puts kaniko more in feature parity with other build tools |
Is there any update? It's an important feature for kaniko. |
Actual behavior
It looks like when I have multi-stage Docker image which have few independent stages to build everything, and then the last stage only to copy files over into the final image, those initial independent stages are not build in parallel.
Expected behavior
Independent stages initial stages could be build in parallel to speed up overall building.
To Reproduce
I used Dockerfile like:
Triage Notes for the Maintainers
--cache
flag(Buildkit-enabled
docker build
call seems to parallelize build run this.)The text was updated successfully, but these errors were encountered: