详解PHP服务器如何在有限的资源里最大提升并发能力


Posted in PHP onMay 25, 2021

概述

假设报考app是用5W rmb 向供应商采购,报名当天涌入海量考生,并发数飙升至30W+,导致系统宕机,拒绝服务,致使考生无法报名,那么5W rmb 能否支持30W+并发呢?

不过对于我们来说,不妨把问题上升一个角度:「如何在有限的资源里最大提升服务器并发能力」。假设你是一名技术负责人,你在面对一个并发量较大的项目时会如何设计和架构呢?

首先我们可以针对这个项目捋一下大体的思路,从上述描述中不难看出,该项目的瓶颈在于「并发写」而非「读」,因此从资源分配上我们可以向「写」倾斜,在此我将数据全部写入在Redis中。除此之外,我们也需要尽量的将MySQL的读操作迁移到Redis上来,MySQL所做的工作更倾向于一些常规非并发的读写操作。

详解PHP服务器如何在有限的资源里最大提升并发能力

服务器

当用户请求过来,由负载均衡器负载到各个服务器上

详解PHP服务器如何在有限的资源里最大提升并发能力

这是一张来自symfony的压测数据,使用的是1 CPU, 4 GB and PHP 7的配置。

详解PHP服务器如何在有限的资源里最大提升并发能力

上图的数据来自于swoole官网,在加上我们在实际业务逻辑的执行之后,可以发现,当我们在使用常驻内存的启动方式时,3台更低配服务器就能解决上述需要16台才能解决的问题。

数据库

其实许多人在接触后端有一定的阶段之后都会了解,现在的许多互联网项目的瓶颈更多的集中在数据库I/O这块,各个语言之间并没有特别大的差距。包括广被大家所诟病的PHP-FPM的启动方式,也可以使用swoole等方式来替代。因此,在这个项目中,会将更多的把精力集中于数据库这一块,可以尝试使用Redis来解决,当然,在具体代码中,也需要提前准备好一定数量的数据连接池。 另外,也考虑MongoDB虽然在同等配置下的写入速度要比MySQL快得多,但是相比于Redis,还是存在明显不足。

注册登录

注册和登录其实应该分成两块来讲,二者分别对应的是「写」和「读」。在高并发读写情况下,直接使用MySQL,如你期待的那样,会爆。因此,我们在构建整个项目的过程中,可以将用户数据缓存到Redis中。 「写」的问题:在用户数量不明确且并发量较大的情况下,我更倾向于用户数据不直接入库。我们可以设计一个开关或阈值,来设置用户的入库方式,当并发大的情况下可以通过MQ来异步让用户入库,而平时则可以正常入库。

提交表单

因为该项目并非我们所常见的秒杀,且需要即时通知的,因此给我们项目的设计大大减少了难度。在提交表单的功能也跟注册类似,我们完全可以让数据异步入库,然后后台审核。

总结

其他的像CDN、MySQL是否需要主从之类的就不再赘述了,视实际情况而定。从理论上,如果使用PHP-FPM的方式,大概需要19000元/月来解决项目的这个问题,而当使用swoole时,大概需要4500元/月,在这里并没有鼓吹swoole,想说明的是当我们在面对大并发项目时,尤其是业务逻辑相对复杂,我们使用常驻内存更能解决问题,而这与语言无关。 最后,需要说明的是,上述仅是理论阶段,至于实际数据如何都需要进一步检验。文章素材来源于网络,如果有写的不正确的地方,望指出。

以上就是详解PHP服务器如何在有限的资源里最大提升并发能力的详细内容,更多关于PHP服务器如何在有限的资源里最大提升并发能力的资料请关注三水点靠木其它相关文章!

PHP 相关文章推荐
怎样在UNIX系统下安装MySQL
Oct 09 PHP
别人整理的服务器变量:$_SERVER
Oct 20 PHP
ThinkPHP php 框架学习笔记
Oct 30 PHP
PHPExcel读取Excel文件的实现代码
Dec 06 PHP
php常用ODBC函数集(详细)
Jun 24 PHP
C#静态方法与非静态方法实例分析
Sep 22 PHP
php数组排序usort、uksort与sort函数用法
Nov 17 PHP
ThinkPHP安装和设置
Jul 27 PHP
在CentOS上搭建LAMP+vsftpd环境的简单指南
Aug 01 PHP
php通过执行CutyCapt命令实现网页截图的方法
Sep 30 PHP
phpcms实现验证码替换及phpcms实现全站搜索功能教程详解
Dec 13 PHP
PHP中ltrim()函数的用法与实例讲解
Mar 28 PHP
详解PHP设计模式之依赖注入模式
阿里云服务器搭建Php+Apache运行环境的详细过程
php+laravel 扫码二维码签到功能
你真的了解PHP中的引用符号(&)吗
php中配置文件保存修改操作 如config.php文件的读取修改等操作
May 12 #PHP
php7中停止php-fpm服务的方法详解
May 09 #PHP
解析laravel使用workerman用户交互、服务器交互
Apr 28 #PHP
You might like
php生成文件
2007/01/15 PHP
php程序的国际化实现方法(利用gettext)
2011/08/14 PHP
用PHP生成excel文件到指定目录
2015/06/22 PHP
解决php的“It is not safe to rely on the system’s timezone settings”问题
2015/10/08 PHP
CentOS下与Apache连接的PHP多版本共存方案实现详解
2015/12/19 PHP
Yii CGridView用法实例详解
2016/07/12 PHP
PHP网站自动化配置的实现方法(必看)
2017/05/27 PHP
浅析PHP中的 inet_pton 网络函数
2019/12/16 PHP
extjs 的权限问题 要求控制的对象是 菜单,按钮,URL
2010/03/09 Javascript
JQuery Easyui Tree的oncheck事件实现代码
2010/05/28 Javascript
js获取指定日期前后的日期代码
2013/08/20 Javascript
jQuery读取XML文件内容的方法
2015/03/09 Javascript
node.js操作mysql(增删改查)
2015/07/24 Javascript
HTML Table 空白单元格补全的简单实现
2016/10/13 Javascript
分享javascript、jquery实用代码段
2016/10/20 Javascript
NodeJS 实现手机短信验证模块阿里大于功能
2017/06/19 NodeJs
微信小程序开发教程之增加mixin扩展
2017/08/09 Javascript
JavaScript中Object基础内部方法图
2018/02/05 Javascript
在Vue中用canvas实现二维码和图片合成海报的方法
2019/06/10 Javascript
Vue 3.x+axios跨域方案的踩坑指南
2019/07/04 Javascript
操作按钮悬浮固定在微信小程序底部的实现代码
2019/08/02 Javascript
js实现前端界面导航栏下拉列表
2020/08/27 Javascript
Python正则抓取新闻标题和链接的方法示例
2017/04/24 Python
PyTorch: 梯度下降及反向传播的实例详解
2019/08/20 Python
Python函数的定义方式与函数参数问题实例分析
2019/12/26 Python
python通过opencv实现图片裁剪原理解析
2020/01/19 Python
Pycharm无法打开双击没反应的问题及解决方案
2020/08/17 Python
最新pycharm安装教程
2020/11/18 Python
css3实例教程 一款纯css3实现的环形导航菜单
2014/10/20 HTML / CSS
家得宝墨西哥官网:The Home Depot墨西哥
2019/11/18 全球购物
商务英语毕业生自荐信范文
2013/11/08 职场文书
婚礼答谢礼品
2015/01/20 职场文书
《巨人的花园》教学反思
2016/02/19 职场文书
周一早安温馨问候祝福语!
2019/07/15 职场文书
导游词之桂林山水
2019/09/20 职场文书
JavaScript函数柯里化
2021/11/07 Javascript