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

Enable Bazel remote caching on more/most continuous/experimental builds by default #8997

Closed
jamiesnape opened this issue Jun 14, 2018 · 8 comments
Labels
component: continuous integration Jenkins, CDash, mirroring of externals, website infrastructure priority: medium unused team: kitware

Comments

@jamiesnape
Copy link
Contributor

A tracking issue for the above. More relevant when bionic support causes the number of jobs to increase more than our CI budget can handle.

FYI @EricCousineau-TRI.

@jamiesnape jamiesnape added the component: continuous integration Jenkins, CDash, mirroring of externals, website infrastructure label Jun 14, 2018
@jamiesnape jamiesnape self-assigned this Jun 14, 2018
@EricCousineau-TRI
Copy link
Contributor

EricCousineau-TRI commented Dec 3, 2018

Per f2f, can close when all PR jobs can use caching (including debug / sanitizer):

Remaining bits:

  • linux-xenial-gcc-bazel-experimental-debug
  • linux-bionic-clang-bazel-experimental-leak-sanitizer

At present, we save some budget, but dev experience is still a little painful due to having to wait for presently non-cached builds (debug, sanitizer).

Will see how things go for the next month to see how budget + dev experience goes.

@jwnimmer-tri
Copy link
Collaborator

FYI At TRI I'm experimenting with turning on Fission for Anzu. Fission should work fine on Bionic at least, and it's on the order of 5x reduction in debug build footprints (80% smaller). I think upstream bazelbuild/bazel#6606 would enable Fission by default on all of our platforms, but it's stalled in review. I wonder if we could help nudge that along, or if there is a 30-line patch to Drake that could have the same effect (declare our own crosstool, but delegate most of it to upstream local_cc).

Fission may also help with #9952.

@jamiesnape
Copy link
Contributor Author

If it's truly mac that is holding them up, I could probably run with it, since I already worked with that code, but not convinced it is. That PR is on the wrong side of bazelbuild/bazel#7320 so would need some work to bring it up to date in any case.

@jamiesnape
Copy link
Contributor Author

jamiesnape commented Feb 15, 2019

(My understanding is that debug fission with -gsplit-dwarf would not work with the Apple compiler at present, but the compiler test in the Bazel PR may erroneously indicate that it is.)

@jamiesnape
Copy link
Contributor Author

bazelbuild/bazel#327 is relevant for Mac.

@jwnimmer-tri
Copy link
Collaborator

Fair enough. Sounds like the low-hanging fruit might be a bionic debug build that is included in the pre-merge set, depending on the crosstool hijinks that we'd need. How about I take a bit more time to see how Anzu fares once I turn this on there, and then we can revisit the question for Drake?

@jamiesnape
Copy link
Contributor Author

Sounds good.

@jwnimmer-tri
Copy link
Collaborator

Per f2f, can close when all PR jobs can use caching (including debug / sanitizer) ...

I just looked at the most recent PR, and all of the jobs appear to be using the remote cache.

@jamiesnape jamiesnape removed their assignment Jun 22, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
component: continuous integration Jenkins, CDash, mirroring of externals, website infrastructure priority: medium unused team: kitware
Projects
None yet
Development

No branches or pull requests

3 participants