打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
web应用请求限流控制

1.当请求量大时,可能会拖垮整个网站,通常会采取限流措施,降低机器的负载。
2.简单的措施是加一个filter拦截器,设置一个静态原子变量,当该变量大于设置的阈值时就直接return返回,不做后续处理,称该方案为方案一。
3.由于方案一的阈值是静态设定的,我们可以采取动态的更改该阈值,即方案一的优化方案。那么该阈值通过什么样的方式更改呢?
(1)存储数据库,定时去数据库中读取。
(2)放在配置中心,定时拉该数据。
称该方案为方案二

4.方案一代码示例:

public class StableControlFilter implements Filter{    private AtomicInteger count = new AtomicInteger();    public void doFilter(final ServletRequest request,final ServletResponse response, final FilterChain chain){        boolean entry=isEntry();        if(entry){            try{                count.incrementAndGet();                chain.doFilter(request,response);            }finally{                count.decrementAndSet();            }        }        return ;    }    private boolean isEntry( ){        if(count > ConfigerConstant.requestCount){            return false;        }        return true;    }}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27

5.方案二中,主要是动态设置阈值ConfgerConstant.requestCount的值。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
一文搞懂高频面试题之限流算法,从算法原理到实现,再到对比分析
简易常用光耦测试电路 只要6个元件
java try、catch、finally及finally执行顺序详解
应该会被限流
#不要限流 #不要限流 #03
求不要限流
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服