时间:2021-07-01 10:21:17 帮助过:20人阅读
1、实际上很多业务无法放到普通的PHP中处理,如一些较复杂的排序、筛选,通过普通的PHP来实现的话效率还不如MYSQL。
2、cache的命中率也不好保证,特别是对一些使用关键词进行查询的业务,关键词变化太多。
若是遇到恶意刷的话,DB服务器容易直接挂掉,因此我们可以在程序层面上加一层限制器,限制并发数,该限制器具备以下特点:
1、高效(废话么,否则直接刷限制器就刷爆了)。现在是使用memcache进行原子操作计数,可以扩展成使用其他方法。
2、精确到action层。可以单独限制单个页面。
3、方便。见仁见智吧
4、成本低廉。包括研发成本与硬件成本。
根据压测,原先只能100并发的搜索功能,限制100后,压测800结果正常。
使用方法如下:
/**
* 搜索
*/
public function search(){
//增加计数器功能,超过次数则返回系统繁忙
$viewlimiter = Library::load('viewlimiter');
//访问限制器的名称,请用controller+action,尽量单个页面保持唯一
$limitName = 'search_search';
//最多同时访问数
$limit = 100;
//若是超过数量则直接返回
if(!$viewlimiter->check($limitName, $limit)) {
ajaxOutput(0, $this->lang->line('multi_search_limit'));
}
/*----复杂变态的业务逻辑-----*/
$xxxModel->search($params);
}
//end func
?>