Guava和RateLimiter限流

复制代码
public class RateLimiterDemo {
    static RateLimiter limiter = RateLimiter.create(2);
    public static class Task implements Runnable{
        @Override
        public void run() {
            System.out.println(System.currentTimeMillis());
        }
    }

    public static void main(String[] args) {
        for(int i=0;i<50;i++){
            //limiter.acquire();
            if(!limiter.tryAcquire()){
                continue;
            }
            new Thread(new Task()).start();
        }
    }
}

当请求成功时,tryAcquire()方法返回true,否则返回false,

该方法不会阻塞。limiter仅支持1秒两次调用,也就是每

500毫秒可用产生一个令牌,显然由于for循环本身的效率高,

完全可用在500毫秒内完成,因此本段代码最终只产生一个输出,

其余请求全部被丢弃?

意思是说 500毫秒内就能执行50次循环,并且只要一次tryAcquire

成功,后续都不会成功?所以只输出一次?

这段代码使用了Guava库中的RateLimiter来限制在特定时间内的请求速率。具体来说,limiter被配置为每秒产生2个令牌,也就是说每500毫秒就会有一个令牌可用。

main方法中的for循环中,你试图启动50个线程,并在每次迭代中尝试获取limiter的令牌。如果tryAcquire成功(即在500毫秒内成功获取到令牌),就会创建一个新的线程并输出当前的系统时间(毫秒级别)。

由于RateLimiter的速率限制为每秒2次,而for循环很快就能执行完,所以在500毫秒内只有一个tryAcquire成功,因此只有一个线程被创建并输出了系统时间。其他的tryAcquire调用因为在500毫秒内无法获取到令牌而失败,所以没有额外的线程被创建。

因此,最终的输出可能只有一次系统时间输出,而其他的请求都因为速率限制而被丢弃。这个例子展示了如何使用RateLimiter来控制代码在一定时间内的执行频率。

相关推荐
qq_12498707531 分钟前
基于协同过滤算法的运动场馆服务平台设计与实现(源码+论文+部署+安装)
java·大数据·数据库·人工智能·spring boot·毕业设计·计算机毕业设计
大飞哥~BigFei3 分钟前
自定义注解记录接口切面log日志入库优化
java
人道领域4 分钟前
javaWeb从入门到进阶(maven高级进阶)
java·spring·maven
一路向北⁢6 分钟前
Spring Boot 3 整合 SSE (Server-Sent Events) 企业级最佳实践(一)
java·spring boot·后端·sse·通信
风象南12 分钟前
JFR:Spring Boot 应用的性能诊断利器
java·spring boot·后端
2401_8576835422 分钟前
为你的Python脚本添加图形界面(GUI)
jvm·数据库·python
m0_7066532326 分钟前
使用Python自动收发邮件
jvm·数据库·python
爱吃山竹的大肚肚26 分钟前
微服务间通过Feign传输文件,处理MultipartFile类型
java·spring boot·后端·spring cloud·微服务
_周游33 分钟前
Java8 API文档搜索引擎_使用内存缓冲区优化
java·搜索引擎·intellij-idea
twj_one34 分钟前
java中23种设计模式
java·开发语言·设计模式