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

利用业务时间做的网站与公司有关吗上海网络营销推广外包

利用业务时间做的网站与公司有关吗,上海网络营销推广外包,青海风控app下载,网站和域名的关系固定算法 原理:固定算法是将时间线分隔成固定大小的时间窗口,每个窗口都会有个计数器,用来记录窗口时间范围内的请求总数,如果窗口的请求总数达到最大限定值,会认定流量超限。比如将窗口大小设为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.15wanjia.com/news/25387.html

相关文章:

  • 黑客编程软件昆明seo网站建设
  • 两学一做材料上哪个网站找semi
  • 怎么建造自己的网站软文广告有哪些
  • 小生意是做网站还是公众号西安seo王
  • 网站内页关键词密度网页推广怎么做
  • 河南网站建设哪里有网站数据
  • 网站开发软件开发项目专业营销团队外包公司
  • 宁波市网站集约化建设通知网站推广计划方法
  • 最新楼盘价格走势图大连seo优化
  • 上海专业网站建设公司今日新闻 最新消息 大事
  • 怎么为做的网站配置域名深圳网络推广公司哪家好
  • 大连华南网站制作公司站长工具seo查询
  • 常州网站关键词优化软件广告软文怎么写
  • 常用网站布局免费网站在线客服系统源码
  • 公司宣传片制作公司广东网站营销seo费用
  • 淮南市城乡建设局网站网络营销企业有哪些公司
  • 如何办宽带张家界seo
  • 软文推广特点淘宝seo搜索优化
  • 网站qq代码seo关键词排名优化价格
  • 济宁建站公司网站怎么进入
  • 如何在网站上做404页面成都网站推广
  • 衡水做企业网站中央新闻
  • 哪个网站是专门做招商的平台长春做网站推广的公司
  • 网络维护公司怎么发展郑州seo排名扣费
  • 做织带的网站厦门seo外包
  • 广州 环保 凡人网站建设网络营销五种方法
  • 好的宝安网站建设长沙网站开发
  • p图做网站兼职网站友链
  • 如何策划电子商务的网站建设百度推广助手客户端
  • wordpress文章添加链接seo包年优化费用