forked from scylladb/scylladb
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrate_limiter.cc
37 lines (32 loc) · 928 Bytes
/
rate_limiter.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
/*
* Copyright (C) 2015-present ScyllaDB
*/
/*
* SPDX-License-Identifier: LicenseRef-ScyllaDB-Source-Available-1.0
*/
#include "rate_limiter.hh"
utils::rate_limiter::rate_limiter(size_t rate)
: _units_per_s(rate) {
if (_units_per_s != 0) {
_timer.set_callback(std::bind(&rate_limiter::on_timer, this));
_timer.arm(lowres_clock::now() + std::chrono::seconds(1),
std::optional<lowres_clock::duration> {
std::chrono::seconds(1) });
}
}
void utils::rate_limiter::on_timer() {
_sem.signal(_units_per_s - _sem.current());
}
future<> utils::rate_limiter::reserve(size_t u) {
if (_units_per_s == 0) {
return make_ready_future<>();
}
if (u <= _units_per_s) {
return _sem.wait(u);
}
auto n = std::min(u, _units_per_s);
auto r = u - n;
return _sem.wait(n).then([this, r] {
return reserve(r);
});
}