On Tue, Jun 07, 2022 at 01:51:06PM +0200, Seena Fallah wrote:
> I also tried with this one but this will give me 20req/s 200 OK and the
> rest of it 429 too many requests
> ```
> listen test
>     bind :8000
>     stick-table  type ip  size 100k expire 30s store http_req_rate(1s)
>     acl exceeds_limit src_http_req_rate gt 100
>     http-request track-sc0 src unless exceeds_limit
>     http-request deny deny_status 429 if exceeds_limit
>     http-request return status 200 content-type "text/plain" lf-string "200
> OK"
> ```
> 
> Maybe the "1s" isn't handled correctly? when I fetch the current value for
> the http_req_rate it is 100 so that makes sense other requests get 429 but
> actually, only 20req/s is responding "200" because the http_req_rate is not
> decreasing in the correct intervals!

There is a reason to this, which is subtle: the counter is updated when
the track action is performed. As such, each new request refreshes the
counter and the counter reports the total number of *received* requests
and not the number of accepted requests.

There are different ways to deal with this, usually they involve a check
*before* the track. With your config it's trivial since you're already
using src_http_req_rate which performs its own lookup. Just move the
track_sc rule at the end and it should be OK.

Willy

Reply via email to