使用guava RateLimiter限流

使用guava RateLimiter限流

    场景:第三方api调用时,避免第三方服务因并发调用数过高挂掉

下面测试例子



private static final RateLimiter rateLimiter =RateLimiter.create(3.0);

public static void main(String[] args) {

for (int i =0; i <30; i++) {

new Thread(() -> {

// System.out.println(currentThread().getName() + "我开始执行了");

      System.out.println(send(currentThread().getName()));

}).start();

}

}

public static String send(String message) {

rateLimiter.acquire();

return sendd(message);

}

public static String sendd(String message) {

return "发送消息:{" + message +"}成功!" +DateUtil.getNow();

}

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,955评论 18 399
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,486评论 19 139
  • JAVA面试题 1、作用域public,private,protected,以及不写时的区别答:区别如下:作用域 ...
    JA尐白阅读 4,862评论 1 0
  • 天灰灰雾蒙蒙 山河寂静 远灯映雪红 寒枝留叶 惆怅空惆怅 为了看一场雪而流浪 穿山过岗 为了见一见你而飘荡 丘壑难...
    甘汝月阅读 1,189评论 0 1