Java实现QPS控制
来源:互联网 发布:数据库软件access 编辑:程序博客网 时间:2024/05/01 03:13
Java实现QPS控制
什么是QPS
QPS:queries per second :每秒的请求数
QPS控制的目的
防止恶意刷取,增加项目负载
解决方案1(假设需要控制在1s内不多于400个请求):
方案描述:
使用数组存储每个请求到来的时间,前400次请求顺利通过,并填满数组。
后续请求到来时,判断当前时间是否比数组中最早的时间晚1s,未晚,则打回,
晚则替换数组中最早的值。循环。
代码实现:
import java.util.Arrays;
import java.util.concurrent.TimeUnit;
public class WindowQpsControl {
/**
* 接受请求窗口
*/
private Long[] accessWindow;
/**
* 窗口大小
*/
private int limit;
/**
* 指针位置
*/
private int curPosition;
/**
* 时间间隔
*/
private long period;
private final Object lock = new Object();
/**
* 1秒内最多400次请求
* @param limit 限制次数 400
* @param period 时间间隔 1
* @param timeUnit 间隔类型 秒
*/
public WindowQpsControl(int limit, int period, TimeUnit timeUnit) {
if (limit < 0) {
throw new IllegalArgumentException("Illegal Capacity: " + limit);
}
curPosition = 0;
this.period = timeUnit.toMillis(period);
this.limit = limit;
accessWindow = new Long[limit];
Arrays.fill(accessWindow, 0);
}
public boolean isPass() {
long curTime = System.currentTimeMillis();
synchronized (lock) {
if (curTime >= period + accessWindow[curPosition]) {
accessWindow[curPosition++] = curTime;
curPosition = curPosition % limit;
return true;
} else {
return false;
}
}
}
}
解决方案2(假设需要控制在1s内不多于400个请求):
方案描述:
使用两个辅助变量:limitPoint:当前时间点,初始化为当前时间
count:通过的访问数,初始化为0,没接收一次请求,自加1
count <= 400时请求可以顺利通过,每通过一次,count++;
count > 400请求到来时,判断当前时间是否比limitPoint晚1s,未晚1s,打回;
满则将limitPoint置为当前时间,count置0。循环。
代码展示:
import java.util.concurrent.TimeUnit;
public class PointQpsControl {
private long limitPoint;
private int count = 0;
/**
* 窗口大小
*/
private int limit;
/**
* 时间间隔
*/
private long period;
private final Object lock = new Object();
/**
* 1秒内最多400次请求
* @param limit 限制次数
* @param period 时间间隔
* @param timeUnit 间隔类型
*/
public PointQpsControl(int limit, int period, TimeUnit timeUnit) {
limitPoint = System.currentTimeMillis();
curPosition = 0;
this.period = timeUnit.toMillis(period);
this.limit = limit;
}
public boolean isPass() {
long curTime = System.currentTimeMillis();
synchronized (lock) {
if (count > limit) {
if (curTime - limitPoint > period) {
limitPoint = curTime;
count = 0;
return true;
} else {
return false;
}
} else {
count++;
return true;
}
}
}
}
方案对比:
综上:还是方案一更好一些
注:这两个方案是我和导师,老大三个人讨论出来的(老大不愧是老大)
0 0
- Java实现QPS控制
- QPS
- QPS
- java实现远程控制
- Java实现控制输入
- Java 超时线程控制实现
- java 实现IP访问量控制
- java多线程实现及控制
- java 实现IP访问量控制
- java实现远程控制应用
- 实现 Java 多线程并发控制框架
- java线程 超时控制的实现
- JAVA实现屏幕抓图 远程桌面控制
- Java实现屏幕抓图,控制远程桌面
- 用JAVA实现的远程桌面控制功能
- 实现 Java 多线程并发控制框架
- JAVA实现屏幕抓图 远程桌面控制
- 实现 Java 多线程并发控制框架--转载
- linux--文件--系统文件和目录 /dev
- 传统的Dialog对话框
- 项目图片
- c#实现动态加载Dll
- 最全的资源教程-前端涉及的所有知识体系
- Java实现QPS控制
- Oracle学习笔记【01】
- mysql字符函数简析
- 图片压缩小例子
- 140个Google面试问题
- HDOJ 1754 I Hate It (线段树单点更新求区间最大值)
- Visualizing and Understanding Convolutional Networks笔记
- spring 事务管理
- intent知识小结