Javaweb應(yīng)用使用限流處理大量的并發(fā)請(qǐng)求詳解
在web應(yīng)用中,同一時(shí)間有大量的客戶端請(qǐng)求同時(shí)發(fā)送到服務(wù)器,例如搶購(gòu)、秒殺等。這個(gè)時(shí)候如何避免將大量的請(qǐng)求同時(shí)發(fā)送到業(yè)務(wù)系統(tǒng)。
第一種方法:在容器中配置最大請(qǐng)求數(shù),如果大于改請(qǐng)求數(shù),則客戶端阻塞。該方法有效的阻止了大量的請(qǐng)求同時(shí)訪問業(yè)務(wù)系統(tǒng),但對(duì)用戶不友好。
第二種方法:使用過濾器,保證一定數(shù)量的請(qǐng)求能夠正常訪問系統(tǒng),多余的請(qǐng)求先跳轉(zhuǎn)到排隊(duì)頁(yè)面,由排隊(duì)頁(yè)面定時(shí)發(fā)起請(qǐng)求。過濾器實(shí)現(xiàn)如下:
public class ServiceFilter implements Filter {
private static final int MAX_COUNT = 20;
private AtomicInteger filterCount = 0;
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
System.out.println("before"+filterCount);
if(filterCount > MAX_COUNT) {
//請(qǐng)求個(gè)數(shù)太多,跳轉(zhuǎn)到排隊(duì)頁(yè)面
request.getRequestDispatcher("index.jsp").forward(request, response);
} else {
//請(qǐng)求個(gè)數(shù)加1
filterCount.incrementAndGet();
chain.doFilter(request, response);
//訪問結(jié)束,請(qǐng)求個(gè)數(shù)減1
filterCount.decrementAndGet();
}
}
此種方式的實(shí)現(xiàn)就是限流??梢詤⒖糝ateLimiter的令牌桶限流策略的實(shí)現(xiàn)。
public class RateLimiterUtils {
private static Logger logger = LoggerFactory.getLogger(RateLimiterUtils.class);
private static final ConcurrentHashMap<String, RateLimiter> resourceLimitMap =
new ConcurrentHashMap<String, RateLimiter>();
/**
* 限流
* @param resource 需要限流的對(duì)象的標(biāo)識(shí)
* @return true表示得到了許可,沒有達(dá)到限流閥值,false表示得不到許可,達(dá)到了限流閥值。
* @author: hejinen
* @date:2016年10月19日 上午11:08:49
*/
public static boolean rateLimit(String resource) {
RateLimiter limit = getRateLimit(resource);
return limit.tryAcquire();
}
/**
* 獲取某個(gè)需限流對(duì)象的RateLimiter,如不存在則創(chuàng)建新的
* @param resouce 需要限流的對(duì)象標(biāo)識(shí)
*/
public static RateLimiter getRateLimit(String resource) {
RateLimiter limit = resourceLimitMap.get(resource);
if(limit == null) {
synchronized(RateLimiterUtils.class) {
limit = resourceLimitMap.get(resource);
double qps = getQpsByResource(resource);
if(limit == null) {
limit = RateLimiter.create(qps);
resourceLimitMap.put(resource, limit);
LoggerUtil.info(RateLimiterUtils.class, "create rate limiter for key:{0},QPS:{1}", resource,qps);
}
}
}
return resourceLimitMap.get(resource);
}
}
總結(jié)
以上就是本文關(guān)于Javaweb應(yīng)用使用限流處理大量的并發(fā)請(qǐng)求詳解的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:javaweb設(shè)計(jì)中filter粗粒度權(quán)限控制代碼示例、Javaweb項(xiàng)目session超時(shí)解決方案、Javaweb使用cors完成跨域ajax數(shù)據(jù)交互等,有什么問題可以隨時(shí)留言,小編會(huì)及時(shí)回復(fù)大家的。感謝朋友們對(duì)本站的支持!
相關(guān)文章
Spring中的策略模式簡(jiǎn)單實(shí)現(xiàn)與使用分析
這篇文章主要介紹了Spring中的策略模式簡(jiǎn)單實(shí)現(xiàn)與使用分析,去初始化時(shí)除了?initMultipartResolver(上傳文件)沒有獲取?Properties?defaultStrategies;默認(rèn)策略,其他的八大件都會(huì)使用到策略模式,需要的朋友可以參考下2024-01-01
使用JDBC實(shí)現(xiàn)數(shù)據(jù)訪問對(duì)象層(DAO)代碼示例
這篇文章主要介紹了使用JDBC實(shí)現(xiàn)數(shù)據(jù)訪問對(duì)象層(DAO)代碼示例,具有一定參考價(jià)值,需要的朋友可以了解下。2017-10-10
Java實(shí)現(xiàn)ZooKeeper的zNode監(jiān)控
這篇文章主要介紹了Java實(shí)現(xiàn)ZooKeeper的zNode監(jiān)控問題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-08-08
Java中將一個(gè)列表拆分為多個(gè)較小列表的三種不同方法
有時(shí)候我們需要將大集合按指定的數(shù)量分割成若干個(gè)小集合,這篇文章主要給大家介紹了關(guān)于Java中將一個(gè)列表拆分為多個(gè)較小列表的三種不同方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-09-09
java 使用BigDecimal進(jìn)行貨幣金額計(jì)算的操作
這篇文章主要介紹了java 使用BigDecimal進(jìn)行貨幣金額計(jì)算的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-02-02
Spring Boot 基于注解的 Redis 緩存使用詳解
本篇文章主要介紹了Spring Boot 基于注解的 Redis 緩存使用詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-05-05

