免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4524 | 回复: 1
打印 上一主题 下一主题

[Redis] 用Redis构建访问频率控制模块 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-02-16 19:29 |只看该作者 |倒序浏览
用Redis构建访问频率控制模块








访问频率控制模块的作用是限制客户端对服务器的访问频率,比如某个IP对某一页面在1分钟内访问一个页面超过100次,那么就返回给客户端一个页面让其输入验证码等。相信经常访问Google的同学都有过被要求输入验证码的经历。

下面是一个使用Redis构建这样一个访问控制模块的例子,其一大特点是可以通过参数对精度与性能之间进行调整。

原理概述:

•程序会确定一个时间片,这个时间片越小,控制精度越高。一个访问控制涉及到多个时间片。
•程序在某个时间要求加入一次访问记录,会先针对当前时间计算要用到的时间片,并对这个时间片的counter加1。
•程序在判断一段时间访问了多少次时,会先计算这段时间包含多少个时间片,然后取出所有这些时间片将counter相加后返回。
原理介绍看这里,程序相关源码在这里(nodejs)

使用示例(nodejs):
  1. var redback = require('redback').createClient(),
  2.     ratelimit = redback.createRateLimit('requests');

  3. //Increment the count for the specified IP
  4. ratelimit.add('127.0.0.1');

  5. //Count the number of requests in the last 20 seconds
  6. ratelimit.count('127.0.0.1', 20, function (err, requests) {
  7.      if (requests > 30) {
  8.          //Throttle the user in some way..
  9.      }
  10. });
复制代码

论坛徽章:
0
2 [报告]
发表于 2012-02-17 22:33 |只看该作者
谢谢分享
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP