详解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 传值赋值与引用赋值的区别
Dec 29 PHP
php实现的获取网站备案信息查询代码(360)
Sep 23 PHP
PHPThumb图片处理实例
May 03 PHP
改写ThinkPHP的U方法使其路由下分页正常
Jul 02 PHP
php实现TCP端口检测的方法
Apr 01 PHP
常见的四种POST 提交数据方式(小总结)
Oct 08 PHP
Smarty高级应用之缓存操作技巧分析
May 14 PHP
使用PHP json_decode可能遇到的坑与解决方法
Aug 03 PHP
php无限级评论嵌套实现代码
Apr 18 PHP
PHP后期静态绑定实例浅析
Dec 21 PHP
php计数排序算法的实现代码(附四个实例代码)
Mar 31 PHP
Thinkphp 框架基础之源码获取、环境要求与目录结构分析
Apr 27 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
我的论坛源代码(十)
2006/10/09 PHP
如何使用PHP往windows中添加用户
2006/12/06 PHP
Laravel中使用Queue的最基本操作教程
2017/12/27 PHP
详解php与ethereum客户端交互
2018/04/28 PHP
刷新页面实现方式总结(HTML,ASP,JS)
2008/11/13 Javascript
一个javascript图片阅览组件
2010/11/09 Javascript
节点的插入之append()和appendTo()的用法介绍
2014/01/13 Javascript
解决checkbox的attr(checked)一直为undefined问题
2014/06/16 Javascript
JavaScript Math.floor方法(对数值向下取整)
2015/01/09 Javascript
JavaScript基础函数整理汇总
2015/01/30 Javascript
使用jquery组件qrcode生成二维码及应用指南
2015/02/22 Javascript
JS实现的最简Table选项卡效果
2015/10/14 Javascript
详解JavaScript的回调函数
2015/11/20 Javascript
JS组件Bootstrap Table表格多行拖拽效果实现代码
2015/12/08 Javascript
完美实现八种js焦点轮播图(上篇)
2016/07/18 Javascript
用JS动态设置CSS样式常见方法小结(推荐)
2016/11/10 Javascript
layui表格实现代码
2017/05/20 Javascript
vue.js选中动态绑定的radio的指定项
2017/06/02 Javascript
Nodejs之TCP服务端与客户端聊天程序详解
2017/07/07 NodeJs
jQuery实现的上传图片本地预览效果简单示例
2018/03/29 jQuery
微信小程序wx.uploadfile 本地文件转base64的实现代码
2018/06/28 Javascript
详解vue axios二次封装
2018/07/22 Javascript
Mint UI实现A-Z字母排序的城市选择列表
2018/12/28 Javascript
浅谈es6中的元编程
2020/12/01 Javascript
[01:15:16]DOTA2-DPC中国联赛 正赛 Elephant vs Aster BO3 第一场 1月26日
2021/03/11 DOTA
Python爬虫之pandas基本安装与使用方法示例
2018/08/08 Python
python删除列表元素的三种方法(remove,pop,del)
2019/07/22 Python
Python调用接口合并Excel表代码实例
2020/03/31 Python
国外平面设计素材网站:The Hungry JPEG
2017/03/28 全球购物
大学本科毕业生的自我鉴定范文
2013/11/19 职场文书
大宝sod蜜广告词
2014/03/21 职场文书
公司请假条格式
2014/04/11 职场文书
质量管理标语
2014/06/12 职场文书
酒店财务总监岗位职责
2015/04/03 职场文书
golang 实现Location跳转方式
2021/05/02 Golang
Python+Selenium实现抖音、快手、B站、小红书、微视、百度好看视频、西瓜视频、微信视频号、搜狐视频、一点号、大风号、趣头条等短视频自动发布
2022/04/13 Python