?Redis?實(shí)現(xiàn)計(jì)數(shù)器和限速器的示例代碼
Redis 是一個(gè)非常適合實(shí)現(xiàn)計(jì)數(shù)器和限速器的工具,因?yàn)樗峁┝烁咝У脑有圆僮?,如自增、自減等。以下是如何使用 Redis 實(shí)現(xiàn)計(jì)數(shù)器和限速器的詳細(xì)示例。
1. 使用 Redis 實(shí)現(xiàn)計(jì)數(shù)器
計(jì)數(shù)器通常用于統(tǒng)計(jì)某個(gè)事件發(fā)生的次數(shù),如用戶點(diǎn)贊數(shù)、頁(yè)面訪問(wèn)次數(shù)等。Redis 提供的 INCR 和 INCRBY 命令可以幫助我們輕松實(shí)現(xiàn)這個(gè)功能。
示例:用戶點(diǎn)贊數(shù)統(tǒng)計(jì)
<?php
class LikeCounter {
private $redis;
public function __construct() {
$this->redis = new Redis();
$this->redis->connect('127.0.0.1', 6379);
}
public function incrementLike($postId) {
$key = "post_likes:$postId";
return $this->redis->incr($key);
}
public function getLikeCount($postId) {
$key = "post_likes:$postId";
return $this->redis->get($key);
}
}
// 示例用法
$likeCounter = new LikeCounter();
$postId = 123; // 假設(shè)這是某個(gè)帖子的ID
// 用戶對(duì)帖子點(diǎn)贊
$newCount = $likeCounter->incrementLike($postId);
echo "Post $postId has $newCount likes.";
// 獲取帖子點(diǎn)贊數(shù)
$currentLikes = $likeCounter->getLikeCount($postId);
echo "Current like count for post $postId: $currentLikes";
2. 使用 Redis 實(shí)現(xiàn)限速器
限速器用于控制某個(gè)操作的頻率,典型場(chǎng)景包括限制用戶訪問(wèn) API 的頻率、搶購(gòu)系統(tǒng)中防止用戶頻繁點(diǎn)擊等。Redis 的 INCR 和 EXPIRE 結(jié)合使用,可以方便地實(shí)現(xiàn)這種功能。
示例:限制用戶 API 訪問(wèn)頻率
<?php
class RateLimiter {
private $redis;
private $maxRequests;
private $timeWindow;
public function __construct($maxRequests, $timeWindow) {
$this->redis = new Redis();
$this->redis->connect('127.0.0.1', 6379);
$this->maxRequests = $maxRequests;
$this->timeWindow = $timeWindow;
}
public function isAllowed($userId, $apiEndpoint) {
$key = "rate_limit:$userId:$apiEndpoint";
$count = $this->redis->incr($key);
if ($count == 1) {
// 設(shè)置過(guò)期時(shí)間
$this->redis->expire($key, $this->timeWindow);
}
if ($count > $this->maxRequests) {
// 超過(guò)最大請(qǐng)求次數(shù)
return false;
}
return true;
}
}
// 示例用法:每分鐘最多允許用戶訪問(wèn)API 10次
$rateLimiter = new RateLimiter(10, 60); // 10次請(qǐng)求,時(shí)間窗口60秒
$userId = 123; // 假設(shè)這是某個(gè)用戶的ID
$apiEndpoint = "/api/buy"; // API 端點(diǎn)
if ($rateLimiter->isAllowed($userId, $apiEndpoint)) {
echo "Request allowed.";
// 執(zhí)行API操作
} else {
echo "Too many requests. Please try again later.";
// 拒絕請(qǐng)求
}
優(yōu)點(diǎn)
- 高效性:Redis 的原子操作確保了在高并發(fā)環(huán)境下的安全性,不會(huì)出現(xiàn)競(jìng)態(tài)條件。
- 可擴(kuò)展性:可以輕松擴(kuò)展到多個(gè)服務(wù)器,以支持更大規(guī)模的用戶和操作量。
- 簡(jiǎn)單性:通過(guò) Redis 的
INCR和EXPIRE命令,能夠輕松實(shí)現(xiàn)復(fù)雜的計(jì)數(shù)和限速邏輯。
總結(jié)
通過(guò) Redis 實(shí)現(xiàn)計(jì)數(shù)器和限速器,不僅提高了系統(tǒng)的性能,還減少了對(duì)數(shù)據(jù)庫(kù)的壓力,特別是在高并發(fā)場(chǎng)景下,比如搶購(gòu)、點(diǎn)贊等操作。
3.舉例短信限制發(fā)送
限制短信發(fā)送頻率是一種常見(jiàn)的防止濫用和避免用戶被騷擾的機(jī)制。通過(guò) Redis 實(shí)現(xiàn)這一功能,可以有效控制同一個(gè)用戶在特定時(shí)間內(nèi)發(fā)送短信的次數(shù)。
實(shí)現(xiàn)思路
我們可以基于 Redis 的計(jì)數(shù)器和過(guò)期時(shí)間功能來(lái)實(shí)現(xiàn)限制短信發(fā)送頻率的功能。具體步驟如下:
- 創(chuàng)建一個(gè)唯一的 Redis Key:該 Key 可以包含用戶的 ID 和短信類(lèi)型(例如驗(yàn)證碼)。
- 使用 Redis 的
INCR命令遞增計(jì)數(shù)器:每次用戶請(qǐng)求發(fā)送短信時(shí),遞增計(jì)數(shù)器。 - 設(shè)置過(guò)期時(shí)間:如果這是計(jì)數(shù)器的第一次遞增操作,為該 Key 設(shè)置一個(gè)過(guò)期時(shí)間(例如 60 秒)。
- 檢查計(jì)數(shù)器的值:如果計(jì)數(shù)器的值超過(guò)了允許的最大次數(shù),則拒絕發(fā)送短信請(qǐng)求。
示例代碼
以下是使用 Redis 限制短信發(fā)送頻率的 PHP 示例代碼:
<?php
class SmsRateLimiter {
private $redis;
private $maxSmsRequests;
private $timeWindow;
public function __construct($maxSmsRequests, $timeWindow) {
$this->redis = new Redis();
$this->redis->connect('127.0.0.1', 6379);
$this->maxSmsRequests = $maxSmsRequests; // 最大允許的短信發(fā)送次數(shù)
$this->timeWindow = $timeWindow; // 時(shí)間窗口(秒)
}
public function canSendSms($userId) {
$key = "sms_limit:$userId";
$count = $this->redis->incr($key);
if ($count == 1) {
// 第一次操作時(shí),設(shè)置過(guò)期時(shí)間
$this->redis->expire($key, $this->timeWindow);
}
if ($count > $this->maxSmsRequests) {
// 超過(guò)最大允許的發(fā)送次數(shù)
return false;
}
return true;
}
}
// 示例用法:限制每個(gè)用戶每 60 秒最多發(fā)送 3 條短信
$smsLimiter = new SmsRateLimiter(3, 60); // 3次請(qǐng)求,時(shí)間窗口60秒
$userId = 123; // 假設(shè)這是某個(gè)用戶的ID
if ($smsLimiter->canSendSms($userId)) {
echo "短信發(fā)送成功";
// 調(diào)用發(fā)送短信的API
} else {
echo "發(fā)送頻率過(guò)高,請(qǐng)稍后再試";
// 拒絕發(fā)送短信
}到此這篇關(guān)于?Redis 實(shí)現(xiàn)計(jì)數(shù)器和限速器的示例代碼的文章就介紹到這了,更多相關(guān)?Redis 計(jì)數(shù)器和限速器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Redis監(jiān)控工具RedisInsight安裝與使用
這篇文章主要為大家介紹了Redis監(jiān)控工具RedisInsight的安裝步驟與使用方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-03-03
Redis使用bloom-filter過(guò)濾器實(shí)現(xiàn)推薦去重
這篇文章主要介紹了Redis使用bloom-filter過(guò)濾器實(shí)現(xiàn)推薦去重,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11
Redis中ServiceStack.Redis和StackExchange.Redis區(qū)別詳解
本文主要介紹了Redis中ServiceStack.Redis和StackExchange.Redis區(qū)別詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
redis通過(guò)lua腳本,獲取滿足key pattern的所有值方式
這篇文章主要介紹了redis通過(guò)lua腳本,獲取滿足key pattern的所有值方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-03-03
淺析PHP分布式中Redis實(shí)現(xiàn)Session的方法
這篇文章主要介紹了PHP分布式中Redis實(shí)現(xiàn)Session的方法,文中詳細(xì)介紹了兩種方法的使用方法,并給出了測(cè)試的示例代碼,有需要的朋友可以參考借鑒,下面來(lái)一起看看吧,2016-12-12
關(guān)于redis Key淘汰策略的實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇關(guān)于redis Key淘汰策略的實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03
Windows操作系統(tǒng)下Redis服務(wù)安裝圖文教程
這篇文章主要介紹了Windows操作系統(tǒng)下Redis服務(wù)安裝圖文教程,文中給大家提供了redis的下載地址,安裝程序步驟,需要的朋友可以參考下2018-03-03

