-
Notifications
You must be signed in to change notification settings - Fork 2.1k
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
Benchmark Prepared statement and expected Improvement #17449
Conversation
Signed-off-by: Harshit Gangal <harshit@planetscale.com>
Signed-off-by: Harshit Gangal <harshit@planetscale.com>
Review ChecklistHello reviewers! 👋 Please follow this checklist when reviewing this Pull Request. General
Tests
Documentation
New flags
If a workflow is added or modified:
Backward compatibility
|
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## main #17449 +/- ##
=======================================
Coverage ? 67.68%
=======================================
Files ? 1584
Lines ? 254505
Branches ? 0
=======================================
Hits ? 172268
Misses ? 82237
Partials ? 0 ☔ View full report in Codecov by Sentry. |
Signed-off-by: Harshit Gangal <harshit@planetscale.com>
6eba850
to
e749db8
Compare
7ff72d5
to
8c74592
Compare
Signed-off-by: Harshit Gangal <harshit@planetscale.com>
8c74592
to
b948875
Compare
A follow-up PR will include the implementation and final performance improvement results. Temporary changes from this commit were used to evaluate the potential improvement. |
@@ -203,7 +163,8 @@ func TestMain(m *testing.M) { | |||
vtgateInstance.ExtraArgs = []string{ | |||
"--mysql_server_query_timeout", "1s", | |||
"--mysql_auth_server_static_file", clusterInstance.TmpDirectory + "/" + mysqlAuthServerStatic, | |||
"--mysql_server_version", "8.0.16-7", | |||
"--pprof-http", |
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.
How do you get the profiles you've pasted in this PR's description? Do you have to query vtgate's http endpoint during while the test is running?
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.
Yes, that is correct.
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.
It could be worth adding a comment on how to get the profiles, so we don't have to look into how the next time.
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.
The curl commands are pretty standard. I will add them up in the follow up PR.
Signed-off-by: Harshit Gangal <harshit@planetscale.com>
5b87b33
to
d1cab71
Compare
Description
Added a benchmark test for prepared statements covering insert, select, update, and delete operations. Utilized this test to analyze heap allocations, revealing that approximately 20% of allocations are consumed in generating a query plan, which can be avoided during prepared statement execution.
Implemented an optimization to bypass query parsing and normalization for already-prepared statements. Benchmark results demonstrated significant query execution performance gains:
The overall geometric mean improvement in query execution across all operations was 4.94%, with potential for further gains as query size increases.
Related Issue(s)
Checklist