详解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 相关文章推荐
解析用PHP读写音频文件信息的详解(支持WMA和MP3)
May 10 PHP
php中自定义函数dump查看数组信息类似var_dump
Jan 27 PHP
php 批量添加多行文本框textarea一行一个
Jun 03 PHP
php防止恶意刷新与刷票的方法
Nov 21 PHP
在php和MySql中计算时间差的方法详解
Mar 27 PHP
PHP+sqlite数据库操作示例(创建/打开/插入/检索)
May 26 PHP
浅谈PHP值mysql操作类
Jun 29 PHP
php中引用&的用法分析【变量引用,函数引用,对象引用】
Dec 12 PHP
php实现的mysqldb读写分离操作类示例
Feb 07 PHP
strpos() 函数判断字符串中是否包含某字符串的方法
Jan 16 PHP
php利用array_search与array_column实现二维数组查找
Jul 08 PHP
php TP5框架生成二维码链接
Apr 01 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中开发XML应用程序之基础篇 添加节点 删除节点 查询节点 查询节
2010/07/09 PHP
php中强制下载文件的代码(解决了IE下中文文件名乱码问题)
2011/05/09 PHP
一个PHP并发访问实例代码
2012/09/06 PHP
深入PHP运行环境配置的详解
2013/06/04 PHP
解析关于wamp启动是80端口被占用的问题
2013/06/21 PHP
php+mysql实现简单的增删改查功能
2015/07/13 PHP
PHP中SSO Cookie登录分析和实现
2015/11/06 PHP
Symfony2获取web目录绝对路径、相对路径、网址的方法
2016/11/14 PHP
Yii 框架使用Forms操作详解
2020/05/18 PHP
Windows Live的@live.com域名注册漏洞 利用代码
2006/12/27 Javascript
JavaScript高级程序设计 错误处理与调试学习笔记
2011/09/10 Javascript
js移除事件 js绑定事件实例应用
2012/11/28 Javascript
jQuery取得设置清空select选择的文本与值
2014/07/08 Javascript
深入学习JavaScript中的原型prototype
2015/08/13 Javascript
JS中JSON对象和String之间的互转及处理技巧
2016/04/06 Javascript
自己动手制作基于jQuery的Web页面加载进度条插件
2016/06/03 Javascript
详解webpack 入门与解析
2018/04/09 Javascript
vue-cli初始化项目中使用less的方法
2018/08/09 Javascript
Node.js创建一个Express服务的方法详解
2020/01/06 Javascript
JavaScript中的Proxy对象
2020/11/27 Javascript
原生JavaScript实现换肤
2021/02/19 Javascript
[05:31]DOTA2英雄梦之声_第08期_莉娜
2014/06/23 DOTA
[01:59]翻天覆地,因你而变,7.20版本地图更新速览
2018/11/24 DOTA
详解Python核心对象类型字符串
2018/02/11 Python
Python中利用aiohttp制作异步爬虫及简单应用
2018/11/29 Python
Python自定义一个类实现字典dict功能的方法
2019/01/19 Python
tensorflow实现二维平面模拟三维数据教程
2020/02/11 Python
python扫描线填充算法详解
2020/02/19 Python
详解Pycharm第三方库的安装及使用方法
2020/12/29 Python
python爬虫破解字体加密案例详解
2021/03/02 Python
优秀体育委员自荐书
2014/01/31 职场文书
高校自主招生教师推荐信
2015/03/23 职场文书
MySQL触发器的使用
2021/05/24 MySQL
浅谈Redis主从复制以及主从复制原理
2021/05/29 Redis
使用php的mail()函数实现发送邮件功能
2021/06/03 PHP
《总之就是很可爱》新作短篇动画《总之就是很可爱~制服~》将于2022年夏天播出
2022/04/07 日漫