Chinaunix首页 | 论坛 | 博客
  • 博客访问: 206647
  • 博文数量: 57
  • 博客积分: 460
  • 博客等级: 一等列兵
  • 技术积分: 405
  • 用 户 组: 普通用户
  • 注册时间: 2010-05-04 23:28
文章分类
文章存档

2015年(1)

2013年(6)

2012年(19)

2011年(31)

分类: iOS平台

2013-05-29 15:39:40


一般来说,一个项目中总是会有一些较难处理的业务,比如业务复杂花样繁多的搜索,使用搜索系统如sphinx,lucence等来处理的话,数据源的若是变化过快(如顶、踩、浏览数之类),则首先推数据的频率就较难衡量,另外无法精确搜索或排序。所以一般情况下的做法是通过DB进行搜索,并且除了尽量将业务分解到程序层面外,还会在DB前加一层cache。但是这样做也有不少已知的弊端:
1、实际上很多业务无法放到普通的PHP中处理,如一些较复杂的排序、筛选,通过普通的PHP来实现的话效率还不如MYSQL。
2、cache的命中率也不好保证,特别是对一些使用关键词进行查询的业务,关键词变化太多。


若是遇到恶意刷的话,DB服务器容易直接挂掉,因此我们可以在程序层面上加一层限制器,限制并发数,该限制器具备以下特点:
1、高效(废话么,否则直接刷限制器就刷爆了)。现在是使用memcache进行原子操作计数,可以扩展成使用其他方法。
2、精确到action层。可以单独限制单个页面。
3、方便。见仁见智吧
4、成本低廉。包括研发成本与硬件成本。


根据压测,原先只能100并发的搜索功能,限制100后,压测800结果正常。

使用方法如下:

点击(此处)折叠或打开

  1. <?php
  2. ????/**
  3. ???? * 搜索
  4. ???? */
  5. ????public?function?search(){
  6. ????????//增加计数器功能,超过次数则返回系统繁忙
  7. ????????$viewlimiter?=?Library::load('viewlimiter');
  8. ????????//访问限制器的名称,请用controller+action,尽量单个页面保持唯一
  9. ????????$limitName?=?'search_search';
阅读(2855) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~