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