-
-
Notifications
You must be signed in to change notification settings - Fork 204
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
feat(docker): use matrix for building multi-platform Docker images #888
Conversation
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## main #888 +/- ##
==========================================
+ Coverage 40.04% 40.10% +0.06%
==========================================
Files 21 21
Lines 1671 1671
==========================================
+ Hits 669 670 +1
+ Misses 1002 1001 -1
Flags with carried forward coverage won't be shown. Click here to find out more. ☔ View full report in Codecov by Sentry. |
Hey! I already mentioned this in the issue that causes this PR, but i guess for the sake of completeness i will leave this here as well. |
Co-authored-by: LtdSauce <[email protected]>
Now we hit another thing: https://github.com/orhun/git-cliff/actions/runs/11075086138/job/30775267343 |
merge-multiple: true | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
merge-multiple: true | |
merge-multiple: true | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3 |
Wow sorry... i just noticed i suggested to remove the wrong lines. The docs mentioned in the description have this step as well, so i guess it is needed for the Docker meta step as well.
This will not solve the issue with the missing docker socket on MacOs though...
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
But still doesn't matter as macos runners on the M1 chip cannot do docker builds anyway.
docker/setup-buildx-action#176 :/ |
it looks like we can use colima actions/runner-images#6216 |
The last two comments mention it is (or at least was) not available on the macos-13 and -14 runners. So i suspect this has to be manually installed. This looks like it is not available on arm based macos nodes. Edit: I am currently experimenting with bringing colima to live... so far no luck. See here My current understanding is, that this has to wait until GitHub launches their linux based arm64 runners. My investigations lead me to the following findings:
This comes to the same conclusion. Another solution would be to somehow split the work that is done in the Dockerfile (basically the compilation) into multiple build stages, and only build one stage in one build step and then use the result in the next build step... but this feels needlessly complex. |
I really appreciate you investing time into this and making everything clear! @LtdSauce - sadly it is an unfortunate situtation.
Can't say that I fully understood it, but yeah, sounds complex for sure.
It might work but sounds too hacky :/ |
Splitting dockerfile will not help as the issue in the build is only triggered in Copying the binary could be a solution for now (a hacky one for sure) but we would needs two differents dockerfile as user wants easy build and we don't want to ask them "build git-cliff localy and then build the dockerfile" (if they want to build it themselves |
Hey,
I kept thinking about my idea. Maybe the following explains it a little better. Disclaimer: i have not enough knowledge about how to split up compilations in cargo. But if i get it right, than it might be possible to do the following as i think i found 3 compilation targets in the project. If i am wrong and there is no way to build things seperately, then please just ignore my comment. Otherwise maybe the following might work: First Adjust the Dockerfile:Instead of doing a full build in Line 14 in bfe9beb
E.g. something like this:
And then in the runner stage use Is it possible to build just the dependencies alone? If so that could be another stage before doing the lib-builder stage. Also as there are 2 binaries in the workspace, those could be build in their own stage as well. This change is not visible to the user of the Dockerfile if one just runs Second split the workflow into multiple jobs:After this something like https://github.com/djbender/github-actions-docker-caching-example/blob/main/.github/workflows/main.yml could be applied to cache each of the above layers in one build job. So basically have one build job for each layer and let them run in sequence. This is necessary as a build job needs to terminate after 6h... splitting the stages over the steps in one job would be easier but is not possible here. Stripped down docker.yml to illustrate it:
Additionally the caching from the above mentioned link has to be used. I have no time to try this out this week though :/ But feel free to adapt my idea if you think it is worth it. (I'll try it out as soon as i have some spare time to fiddle around with this idea.) And this can only work as long as the individual cargo build steps do not take more then 6h each. |
I think you are onto something there... it might work. We should also check out I'm a bit burnt out by these Docker issues recently, feel free to try it out whenever you have time! I might come back to it next week :) |
FTR: I left a comment in the issue that caused this PR as i am now quite certain, that the actual issue lies in the usage of |
Description
See https://docs.docker.com/build/ci/github-actions/multi-platform/#distribute-build-across-multiple-runners
Motivation and Context
Docker builds are hella slow. This might be a way to speed them up.
See #879
How Has This Been Tested?
Not tested yet.
Types of Changes
Checklist: