java高并发场景下的限流策略是什么

发布时间:2021-12-27 17:32:40 作者:iii
来源:亿速云 阅读:107

本篇内容主要讲解“java高并发场景下的限流策略是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“java高并发场景下的限流策略是什么”吧!

为什么需要限流
java高并发场景下的限流策略是什么          

举个比较简单的例子,正常来说,一个员工A他每天能够处理的工作是10个,突然某一天来了100个工作量,这时候,如果员工A还处理100个,只有一种可能,这个员工被压垮。

如果我们能预先知道会有100个任务会来,我们通过增加员工数或定义消息队列等等来临时解决。

但是我们很多时候无法预料这些意外的。根据墨菲定律,坏事往往会接踵而来,有可能某个点挂了会引起全局的挂掉(雪崩)。因此我们不得不对我们的系统做一些保护措施。限流是其中之一。

针对秒杀这类场景,我们也可以做一些限流措施,而不影响到系统全局。

java高并发场景下的限流策略是什么          
限流方式之计数器(滑动窗口协议)
java高并发场景下的限流策略是什么          

思路:限速,我们可能第一个想到的应该是,我通过一个计数器,进行技术,如果超过了计数器阀值,表示速度太快了。一秒一个计数器。

java高并发场景下的限流策略是什么  

为了便于阅读,我只截图了主要的代码片段。

java高并发场景下的限流策略是什么  

这样有个问题就是:粒度太大了,不均匀,针对1秒以下的,没法辨析。

我们能不能把粒度拆细了,1秒拆成10个100毫秒。每一个100毫秒有一个计数器。了解TCP/IP的应该知道,TCP/IP为了增加传输速度和控制传输速度,有个叫“滑动窗口协议”。

就算拆得再细,也无法解决匀速限制速度的问题。

而且还有个临界点问题,假如,一秒限制10个请求,在第1秒和第2秒之间,第1秒后半段时间10个请求,第2秒前半段10个请求,那第1秒后半段+第2秒前半段时间组成的一秒钟里就有20个请求,没有起到限速的作用。

有没有更好的办法呢?

java高并发场景下的限流策略是什么          
限速方式之漏桶算法
java高并发场景下的限流策略是什么          

在生活中,如果一桶有一个细眼,我们往里面装水,可以看到水是一滴一滴匀速的下落的,哪我们能不能通过程序来实现这种方式呢。

思路:桶为容器,一滴水为一请求。如果桶满了就拒绝请求,没满处理请求。

java高并发场景下的限流策略是什么  

代码片段

java高并发场景下的限流策略是什么  

在段代码中

对于很多应用场景来说,除了要求能够限制数据的平均传输速率外,还要求允许某种程度的突发传输。这时候漏桶算法可能就不合适了,令牌桶算法更为适合。

什么意思呢?就是说我服务前面闲了很久,突然来了很多请求(在桶的容量内),我得快速的把这些处理了。

java高并发场景下的限流策略是什么          
限速方式之令牌桶算法
java高并发场景下的限流策略是什么          

思路:匀速的产生令牌,往桶里面丢,每次请求来,看是否有多余的令牌。如果有获取令牌执行正常业务,偌没有限速。

java高并发场景下的限流策略是什么  

代码片段

java高并发场景下的限流策略是什么  

通过这种方式可以允许瞬时的大量处理,然后做限速处理。

以上代码,可在Github查看。
https://github.com/hirudy/java_lib/tree/master/src/main/java/com/hirudy/limiter 

java高并发场景下的限流策略是什么          
单机限速器RateLimiter
java高并发场景下的限流策略是什么          

安利大家一个高效的限速器。

google的基础库guava中包含了一个基于令牌桶的限速器RateLimiter。使用也很简单。

java高并发场景下的限流策略是什么 到此,相信大家对“java高并发场景下的限流策略是什么”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
推荐阅读:
  1. Tomcat 9.0.26 高并发场景下DeadLock问题
  2. 如何使用Redis优化高并发场景下的接口性能

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

java

上一篇:如何基于Flink+ClickHouse 构建实时数据分析平台

下一篇:如何进行Flink作业问题分析和调优实践

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》