import redis
import time
# 连接Redis
r = redis.Redis(host='localhost', port=6379, db=0)
# 滑动窗口限流的实现
def is_rate_limited(key, max_requests, window_size):
# 窗口结束时间
window_end = time.time() + window_size
# 窗口开始时间
window_start = window_end - window_size
# 在Redis中,使用有序集合(zset)记录请求次数,其中成员是key,分数是请求时间戳
requests = r.zrangebyscore(key, window_start, window_end)
# 如果请求数超过限制,则返回True表示被限流
if len(requests) > max_requests:
return True
else:
# 将新的请求加入到zset中
r.zadd(key, {str(time.time()): time.time()})
return False
# 使用示例
key = 'user_requests:123' # 假设用户的ID是123
max_requests = 10 # 时间窗口内最多允许10个请求
window_size = 60 # 时间窗口大小为60秒
if is_rate_limited(key, max_requests, window_size):
print("被限流了")
else:
print("通过了限流")
这段代码首先连接到Redis,然后定义了一个is_rate_limited
函数,该函数使用Redis的有序集合(zset)来实现滑动窗口限流。每次请求时,它会检查在指定时间窗口内的请求次数是否超过了限制。如果超过了,则返回True表示被限流;否则,将这次请求记录在zset中,并返回False表示未被限流。