Redis 是目前 NoSQL 領域的當紅炸子雞,它象一把瑞士軍刀,小巧、鋒利、實用,特別適合解決一些使用傳統關系數據庫難以解決的問題。打算寫一系列 Redis 使用模式的文章,深入總結介紹 Redis 常見的使用模式,以供大家參考。
匯總計數是系統常見功能,比如網站通常需要統計注冊用戶數,網站總瀏覽次數等等。 使用 Redis 提供的基本數據類型就能實現匯總計數器,通過 incr 命令實現增加操作。
速度控制也是 Redis 一種常見的計數用途,比如有一個 API 服務,希望控制每一個 IP 每秒請求數不超過 10 次,可以用 IP 和 時間秒作為 key 設置一個計數器,實現控制,偽代碼如下所示:
# 每秒最大請求數
MAX_REQUESTS_PER_SECOND = 10
# 檢查 ip 請求限制
# @param ip
# @raise 超過限制,拋出 RuntimeError 異常
def check_request_limitation_for_ip(ip)
time_tick = Time.now.to_i
key = "#{ip}:#{time_tick}"
num = $redis.get(key).to_i
if num > MAX_REQUEST_PER_SECOND
raise 'too many requests'
else
$redis.incr(key)
$redis.expire(key, 10)
end
end
有時候需要維護大量計數器,比如每一個論壇主題的查看數,比如每一個用戶訪問頁面次數,因為論壇主題和用戶基數可能很大,直接基于論壇主題或用戶 ID 生成計數器的話,占用 Redis 資源還是相當可觀的,這時可以用 Hash 數據類型壓縮所需資源。