最近由于雙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)儲存的字符串被解釋為十進(jìn)制 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)的最直觀的模式了,它的想法相當(dāng)簡單:每當(dāng)某個操作發(fā)生時,向 Redis 發(fā)送一個 INCR 命令。
比如在一個 web 應(yīng)用程序中,如果想知道用戶在一年中每天的點擊量,那么只要將用戶 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) {
//設(shè)置有效期一s
$this->redis->expire($redisKey,1);//設(shè)置一s的過期時間
}
if (count > 200) {//防止刷單的安全攔截
return false;//超過就返回false
}
//后續(xù)處理
這就簡單的實現(xiàn)了redis計數(shù)器的應(yīng)用,另外還有以下方法:
以下幾種方式擴展這個簡單的模式:
可以通過組合使用 INCR 和 EXPIRE ,來達(dá)到只在規(guī)定的生存時間內(nèi)進(jìn)行計數(shù)(counting)的目的。
客戶端可以通過使用 GETSET 命令原子性地獲取計數(shù)器的當(dāng)前值并將計數(shù)器清零,更多信息請參考 GETSET 命令。
使用其他自增/自減操作,比如 DECR 和 INCRBY ,用戶可以通過執(zhí)行不同的操作增加或減少計數(shù)器的值,比如在游戲中的記分器就可能用到這些命令。
總結(jié)
以上就是本文關(guān)于redis實現(xiàn)計數(shù)器-防止刷單方法介紹的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:Redis的主從同步解析、Java編程redisson實現(xiàn)分布式鎖代碼示例、簡述Redis和MySQL的區(qū)別等,有什么問題可以隨時留言,小編會及時回復(fù)大家的。感謝朋友們對本站的支持!
您可能感興趣的文章:- Redis的使用模式之計數(shù)器模式實例
- Redis實現(xiàn)唯一計數(shù)的3種方法分享
- Redis實現(xiàn)高并發(fā)計數(shù)器
- Spring之借助Redis設(shè)計一個簡單訪問計數(shù)器的示例
- PHP基于redis計數(shù)器類定義與用法示例
- Docker 部署 SpringBoot 項目整合 Redis 鏡像做訪問計數(shù)示例代碼
- redis通過位圖法記錄在線用戶的狀態(tài)詳解
- Redis精確去重計數(shù)方法(咆哮位圖)