文档章节

PHP控制站点并发

有些服务器
 有些服务器
发布于 2015/10/14 20:10
字数 506
阅读 67
收藏 1

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

1、实际上很多业务无法放到普通的PHP中处理,如一些较复杂的排序、筛选,通过普通的PHP来实现的话效率还不如MYSQL。

2、cache的命中率也不好保证,特别是对一些使用关键词进行查询的业务,关键词变化太多。


若是遇到恶意刷的话,DB服务器容易直接挂掉,因此我们可以在程序层面上加一层限制器,限制并发数,该限制器具备以下特点:

1、高效(废话么,否则直接刷限制器就刷爆了)。现在是使用memcache进行原子操作计数,可以扩展成使用其他方法。

2、精确到action层。可以单独限制单个页面。

3、方便。见仁见智吧

4、成本低廉。包括研发成本与硬件成本。


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


使用方法如下:


<?php

    /**

     * 搜索

     */

    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

?>


© 著作权归作者所有

共有 人打赏支持
有些服务器
粉丝 4
博文 49
码字总数 86607
作品 0
南昌
私信 提问
apache限制并发数,IP,带宽设置

给大家推荐两个Apache模块,一个是modvhostlimit,用来限制请求并发数,一个是modlimitipconn,用来控制 Apache的并发联接数,通过该模块可以限制同一来源IP的并发联接数。另一个模块是bwmod...

欣儿
2015/01/09
0
2
从分布式数据库结构入手讲解其前世今生

由于分布式数据库克服了集中式数据库的许多缺点,并且自然地适应于许多单位地理上分散而逻辑上统一的组织结构,因此,20多年以来从理论到实践都得到了迅速发展,并取得了决定性成果。   分...

Oscarfff
2016/06/10
294
0
web压力测试,本机压的结果和内网机压的结果qps差不多,但是php进程使用度却不一样?

压力测试,使用web服务器本机,ab测试, ab -c 1000 -n 10000 http://www.xxxx.com/tp.php 结果为 Requests per second: 463.98 [#/sec] (mean) 压力测试期间观察php-fpm状态页,显示空闲进程...

玖伍陈海天
2017/06/26
218
4
十个免费的WEB压力测试工具

本文列举了是十个免费工具,可以用来进行Web的负载/压力测试的。这样你就可以知道你的服务器以及你的WEB应用能够扛得住多少的并发量,以及网站性能。 0. Grinder � Grinder是一个开源的JVM...

Jay_Wei
2015/12/27
119
0
Nginx网站服务

Nginx网站服务 Nginx专为性能优化而开发,优点是它的稳定性和低系统资源消耗,以及对HTTP并发连接的高处理能力(单台服务器可支持30000 – 50000个并发请求 ) Nginx和Apache的区别 Nginx:只...

常亚亚
2017/05/31
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Oracle学习日志-7(聚合查询)

GROUP BY子句: GROUP BY可以对表进行分割。比如把下面的表按照商品种类进行分割,并列出该商品种类下有多少商品 SQL代码如下 SELECT product_type ,COUNT(*)FROM ProductGROUP BY produc...

白话
10分钟前
0
0
Docker安装mysql8主从结构

准备两台服务器,假设IP地址为 172.31.27.67 主服务器 172.31.27.69 从服务器 因为我用的镜像是docker.io/cytopia/mysql-8.0,所以我们需要先把该镜像给pull下来。 docker pull docker.io/cy...

算法之名
13分钟前
3
0
Springboot集成Ehcache缓存(主要用在登录后做保持会话验证)

EhCache是一个比较成熟的Java缓存框架,最早从hibernate发展而来, 是进程中的缓存系统,它提供了用内存,磁盘文件存储,以及分布式存储方式等多种灵活的cache管理方案,快速简单。 Springbo...

Nonry
15分钟前
0
0
Ajax

1、创建ajax对象 if(window.navigator.userAgent.indexOf('MSIE') > 0){ var xhr = new ActiveXObject('Microsoft.XMLHTTP');}else{ var xhr = new XMLHttpRequest();} 2、get......

lujc
15分钟前
0
0
Flink的基石 : Chandy Lamport Algorithm

Flink处理“流”,对流消息的处理支持三种级别语义分别是“At Most once、At Least once、Exactly once”。 At Most onces:消息最多被处理一次,sender发出消息之后,receiver无论是否处理成...

tantexian
20分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部