cube-js / cube

📊 Cube — The Semantic Layer for Building Data Applications
https://cube.dev
Other
17.49k stars 1.74k forks source link

Evaluate using Profile-Guided Optimization (PGO) and LLVM BOLT #7354

Open zamazan4ik opened 8 months ago

zamazan4ik commented 8 months ago

Is your feature request related to a problem? Please describe. Not a problem - just an idea of how to potentially improve the Cube's performance.

Describe the solution you'd like

Recently I checked Profile-Guided Optimization (PGO) improvements on multiple projects. The results are available here. According to the tests, PGO helps with achieving better performance in many software domains like databases, compilers, network applications, etc. I think trying to optimize Cube (its Rust part since Rust supports PGO) with PGO can be a good idea.

I can suggest the following action points:

Testing Post-Link Optimization techniques (like LLVM BOLT) would be interesting too (Clang and Rustc already use BOLT as an addition to PGO) but I recommend starting from the usual PGO.

Additional context For the Rust projects, I recommend starting with cargo-pgo. More details about PGO support in Rust can be found in the official docs.

Here are some examples of how PGO optimization is integrated in other projects:

github-actions[bot] commented 8 months ago

If you are interested in working on this issue, please leave a comment below and we will be happy to assign the issue to you. If this is the first time you are contributing a Pull Request to Cube.js, please check our contribution guidelines. You can also post any questions while contributing in the #contributors channel in the Cube.js Slack.