利用Redis實現高併發計數器
業務需求中經常有需要用到計數器的場景:譬如一個手機號一天限制傳送5條簡訊、一個介面一分鐘限制多少請求、一個介面一天限制呼叫多少次等等。使用Redis的Incr自增命令可以輕鬆實現以上需求。以一個介面一天限制呼叫次數為例:
/**
* 是否拒絕服務
* @return
*/
private boolean denialOfService(String userId){
long count=JedisUtil.setIncr(DateUtil.getDate()+"&"+userId+"&"+"queryCarViolation", 86400);
if(count<=10){
return false;
}
return true;
}
/**
* 查詢違章
* @param plateNumber車牌
* @param vin 車架號
* @param engineNo發動機
* @param request
* @param response
* @throws Exception
*/
@RequestMapping("/queryCarViolationList.json")
@AuthorizationApi
public void queryCarViolationList(@CurrentToken Token token,String plateNumber,String vin,
String engineNo,HttpServletRequest request,HttpServletResponse response) throws Exception {
String userId=token.getUserId();
//超過限制,攔截請求
if(denialOfService(userId)){
apiData(request, response, ReqJson.error(CarError.ONLY_5_TIMES_A_DAY_CAN_BE_FOUND));
return;
}
//沒超過限制,業務邏輯……
}
每次呼叫介面之前,先獲得下計數器自增後的值,如果小於限制,放行,執行後面的程式碼。如果大於限制,則攔截掉。
JedisUtil工具類:
public class JedisUtil {
protected final static Logger logger = Logger.getLogger(JedisUtil.class);
private static JedisPool jedisPool;
@Autowired(required = true)
public void setJedisPool(JedisPool jedisPool) {
JedisUtil.jedisPool = jedisPool;
}
/**
* 對某個鍵的值自增
* @author liboyi
* @param key 鍵
* @param cacheSeconds 超時時間,0為不超時
* @return
*/
public static long setIncr(String key, int cacheSeconds) {
long result = 0;
Jedis jedis = null;
try {
jedis = jedisPool.getResource();
result =jedis.incr(key);
if (cacheSeconds != 0) {
jedis.expire(key, cacheSeconds);
}
logger.debug("set "+ key + " = " + result);
} catch (Exception e) {
logger.warn("set "+ key + " = " + result);
} finally {
jedisPool.returnResource(jedis);
}
return result;
}
}
原文:https://blog.csdn.net/qq_33556185/article/details/79427271
版權宣告:本文為博主原創文章,轉載請附上博文連結!
相關文章
- 計數器方式實現非同步併發非同步
- php利用pcntl擴充套件實現高併發PHP套件
- 用PHP實現高併發伺服器PHP伺服器
- Redis 實現高併發下的搶購 / 秒殺功能Redis
- Java利用Redis實現非同步邏輯多使用者併發控制JavaRedis非同步
- Redis實現併發阻塞鎖方案Redis
- Redis-高併發篇Redis
- Redis如何防止高併發?Redis
- 線上Redis高併發效能調優實踐Redis
- 【Redis】利用 Redis 實現分散式鎖Redis分散式
- 如何實現Redis裡的自增ID計數器Redis
- 如何利用sockserver模組程式設計實現客戶端併發Server程式設計客戶端
- django框架怎麼實現高併發Django框架
- Nginx 實現高併發的原理分析Nginx
- TCP併發伺服器的程式設計實現TCP伺服器程式設計
- 如何利用 Redis 快速實現簽到統計功能Redis
- PHP利用Mysql鎖解決高併發PHPMySql
- Golang的滑動視窗計數器Redis限速實現GolangRedis
- PHP利用Redis鎖解決併發訪問PHPRedis
- 利用 C++ 11 特性實現多執行緒計數器C++執行緒
- 如何快速實現高併發短文檢索
- 利用Redis實現分散式鎖Redis分散式
- 如何利用 Seaborn 實現高階統計圖表
- 高併發文章瀏覽量計數系統設計
- 【計算機內功心法】七:高併發高效能伺服器是如何實現的計算機伺服器
- Springboot:高併發下耗時操作的實現Spring Boot
- Java ConcurrentHashMap 高併發安全實現原理解析JavaHashMap
- 必殺器!鵝廠首推569頁Netty+Redis+ZK+高併發NettyRedis
- 併發數、併發以及高併發分別是什麼意思?
- 非同步程式設計CompletableFuture實現高併發系統優化之請求合併非同步程式設計優化
- Redis | 第7章 Redis 伺服器《Redis設計與實現》Redis伺服器
- Java利用Scanner 加Swich實現計算器Java
- 2020重新出發,NOSQL,redis高併發系統的分析和設計SQLRedis
- Golang 併發程式設計(channel實現)Golang程式設計
- 關於Redis的幾件小事 | 高併發和高可用Redis
- 關於redis的幾件小事(五)redis保證高併發以及高可用Redis
- 利用 Redis 的 bitmap 實現簡單的布隆過濾器Redis過濾器
- 常用高併發網路執行緒模型效能優化實現-體驗百萬級高併發執行緒模型設計執行緒模型優化