redis應用場景:實現簡單計數器-防止刷單

redis應用場景:實現計數器-防止刷單

最近因爲雙11要來臨,公司須要在接口請求上,作一下併發限制的處理,或者作一個防止刷單的安全攔截:
好比:一個接口請求,限制每秒請求總數爲200次,超過200次就等待,等下一秒,再次請求,這裏用到一個redis做爲一個計數器的模式來實現。php

 

調用redis的方法:

INCR key
將 key 中儲存的數字值增一。web

若是 key 不存在,那麼 key 的值會先被初始化爲 0 ,而後再執行 INCR 操做。redis

若是值包含錯誤的類型,或字符串類型的值不能表示爲數字,那麼返回一個錯誤。api

這是一個針對字符串的操做,由於 Redis 沒有專用的整數類型,因此 key 內儲存的字符串被解釋爲十進制 64 位有符號整數來執行 INCR 操做。
code:
redis> SET test 20
OK
redis> INCR test
(integer) 21
redis> GET test # 數字值在 Redis 中以字符串的形式保存
"21"
安全

計數器的實現

計數器是 Redis 的原子性自增操做可實現的最直觀的模式了,它的想法至關簡單:每當某個操做發生時,向 Redis 發送一個 INCR 命令。併發

好比在一個 web 應用程序中,若是想知道用戶在一年中天天的點擊量,那麼只要將用戶 ID 以及相關的日期信息做爲鍵,並在每次用戶點擊頁面時,執行一次自增操做便可。學習

好比用戶名是 peter ,點擊時間是 2012 年 3 月 22 日,那麼執行命令 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
}
//後續處理
this

這就簡單的實現了redis計數器的應用,另外還有如下方法:code

如下幾種方式擴展這個簡單的模式:接口

能夠經過組合使用 INCR 和 EXPIRE ,來達到只在規定的生存時間內進行計數(counting)的目的。
客戶端能夠經過使用 GETSET 命令原子性地獲取計數器的當前值並將計數器清零,更多信息請參考 GETSET 命令。
使用其餘自增/自減操做,好比 DECR 和 INCRBY ,用戶能夠經過執行不一樣的操做增長或減小計數器的值,好比在遊戲中的記分器就可能用到這些命令。

 
_____________________________________________________________________________________________
歡迎關注公衆號【phper的進階之路】,將不斷更新各類技術心得,免費提供各類學習資源!!!
相關文章
相關標籤/搜索