redis實現(xiàn)計數(shù)器-防止刷單方法介紹
最近由于雙11要來臨,公司需要在接口請求上,做一下并發(fā)限制的處理,或者做一個防止刷單的安全攔截:
比如:一個接口請求,限制每秒請求總數(shù)為200次,超過200次就等待,等下一秒,再次請求,這里用到一個redis作為一個計數(shù)器的模式來實現(xiàn)。
調(diào)用redis的方法:
INCR key
將 key 中儲存的數(shù)字值增一。
如果 key 不存在,那么 key 的值會先被初始化為 0 ,然后再執(zhí)行 INCR 操作。
如果值包含錯誤的類型,或字符串類型的值不能表示為數(shù)字,那么返回一個錯誤。
這是一個針對字符串的操作,因為 Redis 沒有專用的整數(shù)類型,所以 key 內(nèi)儲存的字符串被解釋為十進制 64 位有符號整數(shù)來執(zhí)行 INCR 操作。
code:
redis> SET test 20 OK redis> INCR test (integer) 21 redis> GET test # 數(shù)字值在 Redis 中以字符串的形式保存 "21"
計數(shù)器的實現(xiàn)
計數(shù)器是 Redis 的原子性自增操作可實現(xiàn)的最直觀的模式了,它的想法相當簡單:每當某個操作發(fā)生時,向 Redis 發(fā)送一個 INCR 命令。
比如在一個 web 應用程序中,如果想知道用戶在一年中每天的點擊量,那么只要將用戶 ID 以及相關(guān)的日期信息作為鍵,并在每次用戶點擊頁面時,執(zhí)行一次自增操作即可。
比如用戶名是 peter ,點擊時間是 2012 年 3 月 22 日,那么執(zhí)行命令 INCR peter::2012.3.22 。
$redisKey = “api_name_” + $api;
$count = $this->redis->incr($redisKey);
if ($count == 1) {
//設置有效期一s
$this->redis->expire($redisKey,1);//設置一s的過期時間
}
if (count > 200) {//防止刷單的安全攔截
return false;//超過就返回false
}
//后續(xù)處理
這就簡單的實現(xiàn)了redis計數(shù)器的應用,另外還有以下方法:
以下幾種方式擴展這個簡單的模式:
可以通過組合使用 INCR 和 EXPIRE ,來達到只在規(guī)定的生存時間內(nèi)進行計數(shù)(counting)的目的。
客戶端可以通過使用 GETSET 命令原子性地獲取計數(shù)器的當前值并將計數(shù)器清零,更多信息請參考 GETSET 命令。
使用其他自增/自減操作,比如 DECR 和 INCRBY ,用戶可以通過執(zhí)行不同的操作增加或減少計數(shù)器的值,比如在游戲中的記分器就可能用到這些命令。
總結(jié)
以上就是本文關(guān)于redis實現(xiàn)計數(shù)器-防止刷單方法介紹的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:Redis的主從同步解析、Java編程redisson實現(xiàn)分布式鎖代碼示例、簡述Redis和MySQL的區(qū)別等,有什么問題可以隨時留言,小編會及時回復大家的。感謝朋友們對本站的支持!
相關(guān)文章
Redis總結(jié)筆記(二):C#連接Redis簡單例子
這篇文章主要介紹了Redis總結(jié)筆記(二):C#連接Redis簡單例子,需要的朋友可以參考下2015-01-01
Redis的數(shù)據(jù)過期清除策略實現(xiàn)
Redis實現(xiàn)了數(shù)據(jù)過期清除策略,本文將深入解析Redis的數(shù)據(jù)過期清除策略,包括過期鍵的刪除方式、清除策略的選擇以及相關(guān)配置參數(shù)的介紹,感興趣的可以了解一下2024-05-05
Redis shake實現(xiàn)可視化監(jiān)控的示例代碼
Redis可視化監(jiān)控是通過監(jiān)控Redis服務器的各項指標和狀態(tài),并將其以可視化的方式展示給用戶,本文給大家介紹了Redis shake實現(xiàn)可視化監(jiān)控,并通過代碼示例講解的非常詳細,需要的朋友可以參考下2024-03-03

