如何利用redis来进行分布式集群系统的限流设计

如何利用Redis来进行分布式集群系统的限流设计

作者:张永清 2018-07-16 08:29:54

存储

存储软件

Redis

分布式 在很多高并发请求的情况下,我们经常需要对系统进行限流,而且需要对应用集群进行全局的限流,那么我们如何类实现呢。

在很多高并发请求的情况下,我们经常需要对系统进行限流,而且需要对应用集群进行全局的限流,那么我们如何类实现呢。

我们可以利用redis的缓存来进行实现,并且结合mysql数据库一起,先来看一个流程图。

这个就是一个典型的对http请求进行全局限流的流程图。

入口通过请求拦截器进行拦截(filter)。

来看代码片段,这个代码片段就是一个标准的filter(我们这里基于springboot来定义filter)

我们需要做全局限流时,就需要用到redis了。在redis中,可以将限流配置定义为:

redis key:接口名称(或者url)_limit

 value:map,key:appid(业务id),value:限流大小

就做到配置的快速读取。

限流的配置定义完后,那么就需要定义限流的计数了。可以定义为:

redis key:接口名称(或者url)_count

 value:map,key:appid(业务id),value:计数值

一个好的限流设计,还需要能做到对限流配置的实时进行更改和动态的配置。那我们就来看如何实现呢?

下面就是一个限流配置的新增流程。我们可以将改新增配置定义成一个接口或者页面上的一个功能。就能做到配置的实时增加。

***我们再来看下配置的修改和限流配置的删除。

总结:

我们充分利用redis的缓存配置以及做了限流时,尽量不要影响到系统的整体性能。

分享标题:如何利用redis来进行分布式集群系统的限流设计
浏览地址:http://www.shufengxianlan.com/qtweb/news40/347090.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联