简单PHP控制站点并发数(思路)
2013-06-09 11:03
375 查看
(转)
一般来说,一个项目中总是会有一些较难处理的业务,比如业务复杂花样繁多的搜索,使用 搜索系统如sphinx,lucence等来处理的话,数据源的若是变化过快(如顶、踩、浏览数之类),则首先推数据的频率就较难衡量,另外无法精确搜索 或排序。所以一般情况下的做法是通过DB进行搜索,并且除了尽量将业务分解到程序层面外,还会在DB前加一层cache。但是这样做也有不少已知的弊端:
1、实际上很多业务无法放到普通的PHP中处理,如一些较复杂的排序、筛选,通过普通的PHP来实现的话效率还不如MYSQL。
2、cache的命中率也不好保证,特别是对一些使用关键词进行查询的业务,关键词变化太多。
若是遇到恶意刷的话,DB服务器容易直接挂掉,因此我们可以在程序层面上加一层限制器,限制并发数,该限制器具备以下特点:
1、高效(废话么,否则直接刷限制器就刷爆了)。现在是使用memcache进行原子操作计数,可以扩展成使用其他方法。
2、精确到action层。可以单独限制单个页面。
3、方便。见仁见智吧
4、成本低廉。包括研发成本与硬件成本。
根据压测,原先只能100并发的搜索功能,限制100后,压测800结果正常。
代码如下:
?
扩展话题:
1、若是该业务被刷,可能导致正常用户无法查看内容。 -- 这个问题要解决只能是从系统层面去操作,可见这边:http://johnsteven.blog.51cto.com/2523007/818209
2、限制数最好能与缓存命中率相结合,一定范围内自动变更限制数,提高限制的精准度。 -- 这个后期可以进行研究,与缓存类相结合
3、根据服务器负载进行动态控制。 -- 涉及到底层及服务器权限,研究成本较高,有兴趣的话可以研究。
一般来说,一个项目中总是会有一些较难处理的业务,比如业务复杂花样繁多的搜索,使用 搜索系统如sphinx,lucence等来处理的话,数据源的若是变化过快(如顶、踩、浏览数之类),则首先推数据的频率就较难衡量,另外无法精确搜索 或排序。所以一般情况下的做法是通过DB进行搜索,并且除了尽量将业务分解到程序层面外,还会在DB前加一层cache。但是这样做也有不少已知的弊端:
1、实际上很多业务无法放到普通的PHP中处理,如一些较复杂的排序、筛选,通过普通的PHP来实现的话效率还不如MYSQL。
2、cache的命中率也不好保证,特别是对一些使用关键词进行查询的业务,关键词变化太多。
若是遇到恶意刷的话,DB服务器容易直接挂掉,因此我们可以在程序层面上加一层限制器,限制并发数,该限制器具备以下特点:
1、高效(废话么,否则直接刷限制器就刷爆了)。现在是使用memcache进行原子操作计数,可以扩展成使用其他方法。
2、精确到action层。可以单独限制单个页面。
3、方便。见仁见智吧
4、成本低廉。包括研发成本与硬件成本。
根据压测,原先只能100并发的搜索功能,限制100后,压测800结果正常。
代码如下:
?
1、若是该业务被刷,可能导致正常用户无法查看内容。 -- 这个问题要解决只能是从系统层面去操作,可见这边:http://johnsteven.blog.51cto.com/2523007/818209
2、限制数最好能与缓存命中率相结合,一定范围内自动变更限制数,提高限制的精准度。 -- 这个后期可以进行研究,与缓存类相结合
3、根据服务器负载进行动态控制。 -- 涉及到底层及服务器权限,研究成本较高,有兴趣的话可以研究。
相关文章推荐
- 简单PHP控制站点并发数
- Mysql的锁机制与PHP文件锁处理高并发简单思路
- php学习笔记-会话控制简单介绍session和cookie(一)
- PHP可控制并发数的异步并发CURL
- 一种简单线程并发控制的实现
- 【高并发简单解决方案】redis缓存队列+mysql 批量入库+php离线整合
- php学习之并发控制中的独占锁
- PHP解决抢购、秒杀、抢楼、抽奖等阻塞式高并发库存防控超量的思路方法
- 关于php高并发解决的一点思路
- PHP简单的IoC控制反转实现
- Nginx多站点虚拟主机实现单独启动停止php-fpm、单独控制权限设置
- 并发控制-简单总结
- PHP解决抢购、秒杀、抢楼、抽奖等阻塞式高并发库存防控超量的思路方法
- java web 处理大量用户并发提交的简单思路:队列加定时提交
- 用PHP实现简单的控制反转(IOC) 依赖注入(DI),用JSON配置文件
- PHP解决抢购、秒杀、抢楼、抽奖等阻塞式高并发库存防控超量的思路方法
- 【高并发简单解决方案】redis队列缓存 + 批量入库 + php离线整合
- PHP中利用pcntl进行多进程并发控制
- php控制linux服务器常用功能 关机 重启 开新站点等
- 简单几部思路清晰的教会你配置 Lamp(apache+mysql+php)的配置