-
Notifications
You must be signed in to change notification settings - Fork 5.9k
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
server,executor: split ResultSet Close() to Finish() and Close() #49224
Conversation
Hi @tiancaiamao. Thanks for your PR. PRs from untrusted users cannot be marked as trusted with I understand the commands that are listed here. Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository. |
Codecov Report
Additional details and impacted files@@ Coverage Diff @@
## master #49224 +/- ##
================================================
+ Coverage 71.0414% 71.9100% +0.8686%
================================================
Files 1368 1408 +40
Lines 402903 417448 +14545
================================================
+ Hits 286228 300187 +13959
- Misses 96734 98354 +1620
+ Partials 19941 18907 -1034
Flags with carried forward coverage won't be shown. Click here to find out more.
|
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.
LGTM
[LGTM Timeline notifier]Timeline:
|
/hold |
Hold because it just handle the PointGet case, since PointGet and non-PointGet use different ResultSet implementation, need to add Finish() to both case. |
[APPROVALNOTIFIER] This PR is APPROVED This pull-request has been approved by: lcwangchao, YangKeao The full list of commands accepted by this bot can be found here. The pull request process is described here
Needs approval from an approver in each of these files:
Approvers can indicate their approval by writing |
/unhold |
In response to a cherrypick label: new pull request created to branch |
Signed-off-by: ti-chi-bot <[email protected]>
In response to a cherrypick label: new pull request created to branch |
Signed-off-by: ti-chi-bot <[email protected]>
In response to a cherrypick label: new pull request created to branch |
Signed-off-by: ti-chi-bot <[email protected]>
In response to a cherrypick label: new pull request created to branch |
Signed-off-by: ti-chi-bot <[email protected]>
In response to a cherrypick label: new pull request created to branch |
Signed-off-by: ti-chi-bot <[email protected]>
What problem does this PR solve?
Issue Number: close #48667
Problem Summary:
What changed and how does it work?
In the old interface design,
ResultSet.Close()
may return error, and we must make sure the error is returned to the client, otherwise we get this issue #48446In the previous #48447 I make sure the error is returned, but that cause peformance regression #48667
So the idea is split the work of Close() into two: the part that may return error and the part that may not return error.
We call Finish() first and writeEOF(), then call Close().
Check List
Tests
Run sysbench and get the flamegraph:
Now Close() will be after writeChunks() and there is a Finish() call inside writeChunks().
Side effects
Documentation
Release note
Please refer to Release Notes Language Style Guide to write a quality release note.