Selection of A Suitable Algorithm for the Implementation of Rate-Limiter Based on Bucket4j

Maxim Vitalievich Bartkov, Dmitry Borovikov
2022 International Journal of Online and Biomedical Engineering (iJOE)  
In shared network services, rate limiting is essential as it controls the requests of the users or requesters in a specific amount of time. Due to rate limiting, the service or API stays protected from overuse, malicious attack, DDoS attack, data traffic spikes, etc. Bucket4j is a java library that has been demonstrated to be effective in rate limiting. While Bucket4j is mainly based on token bucket algorithm, rate limiting processes can be based on various effective algorithms. Selecting the
more » ... st suitable algorithm for rate limiting is an essential problem. To address it, we have done a detailed analysis of rate-limiting algorithms based on various factors. The factors we have considered are easy implementation, proper handling of data traffic, data starvation, memory usage, etc. We have found out that for different set of requirements, different algorithms are preferable.
doi:10.3991/ijoe.v18i04.25641 fatcat:nr5pjfzvm5cfbdjphfmtfsh24i