Skip to content
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

ratelimit: per descriptor hits addend support and prefer uint64 #802

Merged
merged 5 commits into from
Dec 27, 2024

Conversation

wbpcode
Copy link
Member

@wbpcode wbpcode commented Dec 23, 2024

No description provided.

Copy link
Member

@mathetake mathetake left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

high level question: if the number zero is given, it should work like "check the budget is not negative, and if not requests are allowed"? I am asking because if this would obviate the issue we had in #729

Signed-off-by: wangbaiping/wbpcode <[email protected]>
@wbpcode
Copy link
Member Author

wbpcode commented Dec 23, 2024

high level question: if the number zero is given, it should work like "check the budget is not negative, and if not requests are allowed"? I am asking because if this would obviate the issue we had in #729

The counter in redis is a number that counts all used tokens. So, we only need to check if the counter is larger than the threshold or not.

@mathetake
Copy link
Member

cool, so in other words, sending hits_addend=0 can be used to reject requests if the counter in redis is negative or zero ya?

Signed-off-by: wangbaiping/wbpcode <[email protected]>
@wbpcode
Copy link
Member Author

wbpcode commented Dec 23, 2024

cool, so in other words, sending hits_addend=0 can be used to reject requests if the counter in redis is negative or zero ya?

sorry, I may didn't make it clear. The counter will never be negative in the redis. It is a counter the will increases forever in the time window.

But the conclusion is right. hits_addend zero could also could be used to reject a request.

@mathetake
Copy link
Member

great, thank you for clarifying!

Signed-off-by: wangbaiping/wbpcode <[email protected]>
@wbpcode
Copy link
Member Author

wbpcode commented Dec 23, 2024

cc @psbrar99

@mathetake
Copy link
Member

also @zirain if you have any comments

@@ -41,7 +41,7 @@ func CalculateReset(unit *pb.RateLimitResponse_RateLimit_Unit, timeSource TimeSo
return &durationpb.Duration{Seconds: sec - now%sec}
}

func Max(a uint32, b uint32) uint32 {
func Max(a uint64, b uint64) uint64 {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

not a must, but is it find to remove this as golang support generic?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I am not very familiar to go (I use c++ at most times orz), so not sure if a new generic Max is provided by the golang stdlib or not. If it is provided, it would be great to remove this function.

Copy link
Member

@zirain zirain Dec 23, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

// The max built-in function returns the largest value of a fixed number of
// arguments of [cmp.Ordered] types. There must be at least one argument.
// If T is a floating-point type and any of the arguments are NaNs,
// max will return NaN.
func max[T cmp.Ordered](x T, y ...T) T

looks like there's.

Copy link
Member

@zirain zirain left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM, only a small nit.

Signed-off-by: wangbaiping/wbpcode <[email protected]>
@psbrar99
Copy link

LGTM, thanks @wbpcode .

@psbrar99 psbrar99 self-requested a review December 27, 2024 01:03
@psbrar99 psbrar99 merged commit 38500fe into envoyproxy:main Dec 27, 2024
6 checks passed
@mathetake
Copy link
Member

fantastic, thank you for your hard work! @wbpcode 👯

@wbpcode wbpcode deleted the dev-per-descriptor-hits-addend branch December 27, 2024 02:49
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants