当前位置: 首页 > news >正文

中国旅游网站排名重庆网站seo多少钱

中国旅游网站排名,重庆网站seo多少钱,网页制作素材源代码,域名做违法网站固定算法 原理:固定算法是将时间线分隔成固定大小的时间窗口,每个窗口都会有个计数器,用来记录窗口时间范围内的请求总数,如果窗口的请求总数达到最大限定值,会认定流量超限。比如将窗口大小设为1分钟,每分…

固定算法

原理:固定算法是将时间线分隔成固定大小的时间窗口,每个窗口都会有个计数器,用来记录窗口时间范围内的请求总数,如果窗口的请求总数达到最大限定值,会认定流量超限。比如将窗口大小设为1分钟,每分钟请求最大数为2:
在这里插入图片描述
请求在00:00:24时刻到来的时候,会落在窗口1内,计数器值为1,下一个请求在00:00:36时刻,也会落在窗口1内,计数器值+1变成,第三个请求在00:00:49时刻来到,此时计数器值已达到最大限定值2,请求会被拒掉,最后一个请求在00:01:12到来,会落在窗口2内。

固定算法的缺点

固定算法只能判断单个窗口内的请求总数,但是无法判断相邻的两个窗口,落在相邻窗口的两个请求时间间隔完全有可能在一个窗口时间范围内。比如00:00:58和00:00:59两个时刻各有一个请求过来,窗口1的计数器值为2, 第三个请求在00:01:01到来,会落在窗口2内,但是00:00:58和00:01:01之间没有超过一个单元时间1分钟,但是请求总数已经超过最大限定值2。

滑动窗口算法

为了优化固定算法的缺点,将固定大小的时间窗口分成更小的时间窗口,比如1min的窗口分成6个10s的小窗口。

实现一(简单无脑版)

思路:

1.   使用一个Map:counterMap 用来存储每个时间戳的请求总数
2.   请求到来时,会将单位时间之前(now-timeUnit)的所有请求记录全部清除
3.   统计单位时间timeUnit内的请求总数
4.   判断请求总数是否超过请求阈值capacity,超过则返回false
5.   没有超过,则记录当前时间戳和请求。

源码:

public class SlidingWindow3 {/*** 单位时间请求阈值*/private int capacity;/*** 单位时间/ms*/private long timeUnit;/*** 时间戳计数器*/private Map<Long,Integer> counterMap = new HashMap<>();public SlidingWindow3(int capacity, long timeUnit) {this.capacity = capacity;this.timeUnit = timeUnit;}public synchronized boolean tryAcquire() {long now = System.currentTimeMillis();long start = now-timeUnit;Iterator<Map.Entry<Long, Integer>> iterator = counterMap.entrySet().iterator();while (iterator.hasNext()){if(iterator.next().getKey()<start){iterator.remove();}}iterator = counterMap.entrySet().iterator();int totalCount = 0;while (iterator.hasNext()){totalCount += iterator.next().getValue();}if(totalCount>= capacity){return false;}if(counterMap.containsKey(now)){counterMap.put(now,counterMap.get(now)+1);}else {counterMap.put(now,1);}return true;}
}

测试

 public static void main(String[] args) throws InterruptedException {SlidingWindow3 slidingWindow = new SlidingWindow3(2, 1000);for (int j = 0; j < 10; j++) {System.out.println("第:" + j + "轮测试");int concurrency = 30;CyclicBarrier cyclicBarrier = new CyclicBarrier(concurrency);for (int i = 1; i <= concurrency; i++) {new Thread("Thread:" + i) {@Overridepublic void run() {try {cyclicBarrier.await();if (slidingWindow.tryAcquire()) {System.out.println("name:" + Thread.currentThread().getName() + " get permit");}} catch (InterruptedException e) {e.printStackTrace();} catch (BrokenBarrierException e) {e.printStackTrace();}}}.start();}Thread.sleep(3 * 1000L);}}

结果

在这里插入图片描述

参考

《Rate-Limiter-Part1》

http://www.yidumall.com/news/412.html

相关文章:

  • 西安网站建设的费用济南网站优化公司排名
  • 商场网站建设广告营销留电话网站
  • 六安短视频优化费用seo排名培训公司
  • 怎样做电商网站好视频教学上海今天发生的重大新闻
  • 网站域名中文后缀永久免费不收费的污染app
  • 凡科建站登录入口官方正版阿里巴巴国际站官网
  • 网站建设流程表怎么在百度上设置自己的门店
  • 化妆品网页设计模板素材苏州网站关键词优化推广
  • ftp网站备份百度搜索网
  • 服装电子商务网站设计百度网盘官方
  • 佛山品牌网站设计谷歌网站优化
  • 如何提升网站的流量天津网站策划
  • 做网站维护累吗免费b站推广网站在线
  • 内蒙古建设厅官方网站路由优化大师
  • wordpress分页调用代码沈阳seo排名优化推广
  • 无需注册免费的网站江苏网页定制
  • 云南公司网站开发seo技术专员招聘
  • 人民政府网站的信息资源建设seo关键词优化排名公司
  • 网络营销模式有几种西安seo培训
  • 网站背景居中怎么做网店运营工作内容
  • 修复WordPress图片上传错误南京关键词优化服务
  • 旅游业网站建设方案特点谷歌安装器
  • 设计师常去的素材网站十大计算机培训学校
  • 建设银行互联网站黑科技引流工具
  • 有没有帮忙做网站怎么制作网站平台
  • 苏州网站公安备案设计网站接单
  • 手机网站的建设北京谷歌seo
  • 全椒有做网站的吗wifi优化大师下载
  • 卡盟网站模板百度推广代理加盟
  • 建设网站的申请信用卡吗百度收录怎么查询