commit | a6d7dc78891a1bc8d8da19bbd29a5bb320034661 | [log] [tgz] |
---|---|---|
author | Googler <noreply@google.com> | Mon Aug 27 11:18:15 2018 -0700 |
committer | Copybara-Service <copybara-piper@google.com> | Mon Aug 27 11:19:59 2018 -0700 |
tree | 033177504d68d1620c18b5a17742b283f8f3b921 | |
parent | 38673e893fad7e9b20735d49390bbad26a25b7bb [diff] |
Use a ForkJoinPool instead of a PriorityBlockingQueue-based ThreadPoolExecutor for the analysis phase. During the analysis phase, lots of very short actions are executed (File, FileState, ...) and contention in the executor has a substantial performance impact. Contention has always been a problem here, but the move towards rightfully using PriorityBlockingQueue can cause even more work to be executed under a lock. While I couldn't measure substantial wall-time differences between PriorityBlockingQueue and the previously used LinkedBlockingQueue, this change improves performance by about 10% on a variety of experiments I have conducted. RELNOTES: None. PiperOrigin-RevId: 210398382
{Fast, Correct} - Choose two
Build and test software of any size, quickly and reliably.
Speed up your builds and tests: Bazel only rebuilds what is necessary. With advanced local and distributed caching, optimized dependency analysis and parallel execution, you get fast and incremental builds.
One tool, multiple languages: Build and test Java, C++, Android, iOS, Go, and a wide variety of other language platforms. Bazel runs on Windows, macOS, and Linux.
Scalable: Bazel helps you scale your organization, codebase, and continuous integration solution. It handles codebases of any size, in multiple repositories or a huge monorepo.
Extensible to your needs: Easily add support for new languages and platforms with Bazel's familiar extension language. Share and re-use language rules written by the growing Bazel community.
Follow our tutorials:
See CONTRIBUTING.md
Bazel is released in ‘Beta’. See the product roadmap to learn about the path toward a stable 1.0 release.