-
Notifications
You must be signed in to change notification settings - Fork 1.8k
Write rate limit batch update per point count #6152
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
Conversation
@@ -54,8 +54,7 @@ impl ShardReplicaSet { | |||
let result = match state { | |||
ReplicaState::Active => { | |||
// Rate limit update operations on Active replica | |||
// TODO(ratelimits) determine cost of update based on operation |
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.
used to be always 1 token per update
@@ -296,19 +295,11 @@ impl ShardReplicaSet { | |||
|
|||
if self.peer_is_active(this_peer_id) { | |||
// Check write rate limiter before proceeding if replica active | |||
// TODO(ratelimits) determine cost of update based on operation | |||
|
|||
self.check_write_rate_limiter_lazy(&hw_measurement_acc, || { |
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.
this path already had the fix in place, just needed to refactor to share it
📝 WalkthroughWalkthroughThis change introduces a new method, Possibly related PRs
Suggested reviewers
📜 Recent review detailsConfiguration used: CodeRabbit UI 📒 Files selected for processing (2)
🧰 Additional context used🪛 Ruff (0.8.2)tests/openapi/test_strictmode.py1094-1094: Redefinition of unused (F811) 1134-1134: Redefinition of unused (F811) 🔇 Additional comments (6)
✨ Finishing Touches
Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out. 🪧 TipsChatThere are 3 ways to chat with CodeRabbit:
Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (Invoked using PR comments)
Other keywords and placeholders
CodeRabbit Configuration File (
|
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.
Nice usage of OperationAffectArea
This PR makes sure all update operation are priced according to the content of their content.
It leverages an existing infrastructure for computing the cost of updates from #5729.