-
Notifications
You must be signed in to change notification settings - Fork 13k
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
CI: move dist-arm-linux
to an ARM runner
#133902
Conversation
@bors try |
CI: move `dist-arm-linux` to a free runner Related issue: rust-lang/infra-team#181 First, I want to test whether we could actually move this to a free runner, vs moving to the 8-core ARM runner. r? `@MarcoIeni` try-job: dist-arm-linux
I tried to move it to free runners in #133256 (comment) but it was taking a bit too long. |
True, but since then we have merged several changes where 2h 37m would be deemed acceptable, right? So at least wanted to try it again. |
By looking at the average ci time, it looks like the minimum is 2h 40min, so yes, it's acceptable, but in some cases it might be the slowest job. We can merge this and monitor over time to check if it becomes an issue 👍 |
Also, it would be cool to be able to split dist jobs, e.g. one job could build rust-analyzer, another one could build clippy, rustfmt, etc. But I'm not sure if it's feasible |
sync @bors r- |
Sorry for the inconvenience, bors seems stuck. @bors try |
CI: move `dist-arm-linux` to a free runner Related issue: rust-lang/infra-team#181 First, I want to test whether we could actually move this to a free runner, vs moving to the 8-core ARM runner. r? `@MarcoIeni` try-job: dist-arm-linux
This comment has been minimized.
This comment has been minimized.
67c6629
to
28767a1
Compare
Not enough space. Nevermind. @bors try |
CI: move `dist-arm-linux` to a free runner First, I want to test whether we could actually move this to a free runner, vs moving to the 8-core ARM runner. Fixes: rust-lang/infra-team#181 r? `@MarcoIeni` try-job: dist-arm-linux
This comment has been minimized.
This comment has been minimized.
💔 Test failed - checks-actions |
Done (I kept two commits, since they are independent). |
@bors r+ |
@bors rollup=iffy |
@@ -19,7 +19,7 @@ RUN sh /scripts/rustbuild-setup.sh | |||
WORKDIR /tmp | |||
|
|||
COPY scripts/crosstool-ng-build.sh /scripts/ | |||
COPY host-x86_64/dist-arm-linux/arm-linux-gnueabi.defconfig /tmp/crosstool.defconfig | |||
COPY host-aarch64/dist-arm-linux/arm-linux-gnueabi.defconfig /tmp/crosstool.defconfig |
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.
So it sounds like this is still a normal cross-compilation job, it now just happens to use an aarch64 host in CI. Can we drop this host-aarch64/host-x86_64 distinction for jobs where it is not relevant? Otherwise it will not be possible to test this image locally (on x86_64) anymore.
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.
Basically, as far as I can tell, there is no relation at all here between the fact that this is dist-arm-linux and we're running on ARM. You could do exactly the same move for all/most other crosstool-ng based jobs, if the ARM runners are cheaper for you.
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.
Good point. But based on your comment from the other PR, moving to a native build would raise the minimum glibc version, right? Since this already used crosstool before, we could make use of it to keep glibc lower.
The cost calculation here is that, as long as it takes less than 60% longer to run, it's cheaper to use the aarch64 runners instead of the x86_64 ones, right? |
Yes, the ARM64 runners are in fact cheaper than x64 runners at the moment (somewhat surprisingly to me). In theory, we could start moving all/most large runners from x64 to ARM, but we wanted to test it first with jobs that are the "most relevant" ( However, as you correctly pointed out, this PR does not switch away from it, and more importantly, switching away from it in the native way, by just using ubuntu 22.04, would increase our minimum glibc support, which is bad. So we can either keep using crosstool, or migrate the ARM jobs to a similar design as we use for x64. But that would be quite annoying, I can imagine, because on the CentOS we need to install a bunch of things from scratch. In the longer term, we'd like to unify the Dockerfile base images to avoid so much duplication; it might be better to delay a large change like this until then. |
Right. I think switching from crosstool-ng to a native build only makes sense for tier 1 targets (like dist-aarch64-linux) where we want to apply PGO optimizations. For things like dist-arm-linux, sticking to the cross-compiled build gives us a lot more control over the target requirements. Just moving the images to a different host, while keeping cross-compilation, still makes sense from a cost perspective. If we do that, I'd mainly just want to retain the ability to easily run the images on x86_64. Probably just having a host-any directory next to host-x86_64 and host-aarch64 would be enough for that. |
Yes, this PR was done because of the reduced cost, just to test it out (switching a single runner won't exactly save our CI budget). Our current way of running CI jobs locally isn't great, and with the latest CI changes, it's actually becoming worse, as some jobs are being split (although this isn't happening yet for On a related note, we should probably have some tests that check what glibc do our dist toolchains require, as currently it's not being tested anywhere, AFAIK. And if you haven't caught this on the PR, we could have landed a glibc bump inadvertedly (although probably sooner or later someone would complain). I created an issue for that: #134037. |
(sorry for the off-topic but: this would be extremely valuable for contributors and imo sounds worthy of a t-infra project goal; possibly orphaned if no one has availability to work on it but can help with mentoring and reviews of external contributions) |
…Ieni CI: move `dist-arm-linux` to an ARM runner First, I want to test whether we could actually move this to a free runner, vs moving to the 8-core ARM runner. Fixes: rust-lang/infra-team#181 r? `@MarcoIeni` try-job: dist-arm-linux
Rollup of 5 pull requests Successful merges: - rust-lang#128004 (codegen `#[naked]` functions using global asm) - rust-lang#132789 (add some debug-assertion crash tests) - rust-lang#133456 (Add licenses + Run `cargo update`) - rust-lang#133853 (use vendor sources by default on dist tarballs) - rust-lang#133902 (CI: move `dist-arm-linux` to an ARM runner) r? `@ghost` `@rustbot` modify labels: rollup
☀️ Test successful - checks-actions |
Finished benchmarking commit (b597d2a): comparison URL. Overall result: no relevant changes - no action needed@rustbot label: -perf-regression Instruction countThis benchmark run did not return any relevant results for this metric. Max RSS (memory usage)Results (primary -3.6%, secondary 4.7%)This is a less reliable metric that may be of interest but was not used to determine the overall result at the top of this comment.
CyclesThis benchmark run did not return any relevant results for this metric. Binary sizeThis benchmark run did not return any relevant results for this metric. Bootstrap: 767.281s -> 767.346s (0.01%) |
Revert "Auto merge of rust-lang#133902 - Kobzol:ci-dist-arm-runner, r=MarcoIeni" Reverts rust-lang#133902 Context: rust-lang#134612 (comment)
First, I want to test whether we could actually move this to a free runner, vs moving to the 8-core ARM runner.
Fixes: rust-lang/infra-team#181
r? @marcoieni
try-job: dist-arm-linux