摘要:如何使用优化高并发场景写库或者耗时计算在的接口中使用消息队列,把要入库的数据写入的类型中。高容错子进程异常奔溃时,主进程将重建子进程。高性能多进程运行,充分利用多个并行计算,性能强劲。
经常在群里听到一些朋友问:TP 的项目怎么迁移到 mixphp 来处理高并发,我通常都是回复需要重写,可是一个开发很久的 TP 项目,代码量巨大,又怎么可能会花大量时间成本来重写呢?
那么为何我们不尝试换一种思路来解决问题?
在现有框架不变的情况下,引入 mixphp 来处理高并发的部分。瓶颈分析
二八效应在任何领域都存在,如果你做过多个项目,你就会发现:
一个项目中高并发的接口或页面,通常只占到项目的 20% 以下。具体会有哪些场景
一些常见的高并发场景的问题:
APP 用户数据采集接口:由于是通过接口按秒定时上传用户数据,随着用户量的增长,QPS 极高,该类型需求是写库动作,无法使用缓存优化。
股票行情展示:由于需每秒查询股票的实时数据,随着用户量的增长,QPS 极高,即便可以使用缓存给数据库减压,但是频繁的请求任然使应用服务器不堪重负。
一些常见的大量计算场景的问题:
定时统计:定时统计表中大量的数据,一个进程计算太慢,多个进程计算又有数据不同步的问题。
如何使用 mixphp 优化 1. 高并发场景(写库 / 或者耗时计算):在 TP 的接口中使用消息队列,把要入库的数据写入 redis 的 list 类型中。
$redis->lpush($key, $data);
然后在 mixphp 中使用多进程服务来消费这个队列:
DEMO (V1):https://github.com/mix-php/mi...
mixphp 的多进程服务有很多传统框架所不具备的特点:
平滑重启:当 kill 主进程时,子进程处理完工作再退出,不丢失数据。
高容错:子进程异常奔溃时,主进程将重建子进程。
高性能:多进程运行,充分利用多个CPU并行计算,性能强劲。
使用灵活:工作进程使用生产者消费者模型,生产者/消费者的数量都可自定义。
2. 高并发频繁查询场景(增加缓存依然达到瓶颈):该种场景瓶颈已经不在数据库,因为 HTTP 接口是请求响应式,如此频繁的请求,不断的建立与关闭连接消耗了太多的服务器性能,这时需使用长连接协议 WebSocket 来优化。
使用 mixphp 的 WebSocketd 封装,能很快就搭建一个数据推送系统,解决 API 轮询的性能瓶颈:
DEMO (V1):https://github.com/mix-php/mi...
3. 大量数据计算场景:如果从一个数据表中取出大量数据,一个进程计算又太慢了,如果分多个进程分页去查询后,再分开计算,速度是快了,但是如果查询中数据有变化,因为每个进程分别会查一次数据库,就会导致有的数据遗漏没有计算到、有的又被多次计算,导致计算结果错误。
这时使用 mixphp 的多进程服务就不会有这个问题,mixphp 的多进程服务在进程内部做了生产者消费者模型,只需使用一个进程去数据表取出数据,然后一行一行发送给消费者进程去计算,这样就高效安全的完成了一次大量计算。
MixPHPGitHub: https://github.com/mixstart/m...
官网:http://www.mixphp.cn/
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/30713.html
摘要:消费者开发本例我们使用的多进程开发工具来完成这个需求,通常使用常驻进程来处理队列的消费,所以我们使用的类型,模式。中进程负责执行邮件发送任务。此时终端将打印成功收到测试邮件官网 注意:这个是 MixPHP V1 的范例 邮件发送是很常见的需求,由于发送邮件的操作一般是比较耗时的,所以我们一般采用异步处理来提升用户体验,而异步通常我们使用消息队列来实现。 传统 MVC 框架由于缺少多进程...
摘要:框架最新源代码行数行,因此可以很容易的改造它,成为你们公司的专属框架。也不同于其他基于的微服务框架,只聚焦于微服务治理,定位于开发的更多领域,覆盖从初创到亿元级体量的技术诉求。的授权全靠用户自愿购买,详情 MixPHP是什么 MixPHP 是秉承 普及 PHP 常驻内存型解决方案,促进 PHP 往更后端发展 的理念而创造,采用 Swoole 扩展作为底层引擎,围绕常驻内存的方式而设计,...
摘要:由于是基于的传统框架,如果使用的正常部署方式来对比,显得有些不公平,由于同时支持在中运行,所以此次测试的是部署在之中。你也来测试一下吧, MixPHP 是一个基于 Swoole 的高性能框架,CodeIgniter 是一个元老级的轻量级框架,Yii 是一个非常流行的框架,以下是三个框架的对比。 由于 Yii/CodeIgniter 是基于 Apache/PHP-FPM 的传统框架,如果...
摘要:异步队列消费者开发只提供了模式下运行控制器方法,并未提供主进程多子进程的进程模型,并未提供多线程处理。多线程异步队列服务只需写好控制器方法,然后在配置文件中配置下路由命名空间进程线程数量,就可在模式中启动多进程多线程模型的异步队列处理程序。 最近业余时间一直在开发ExpressPHP的第二个版本 MixPHP,今天下班想起之前一个面试官的问题:你为什么还要再造一个轮子呢?仔细回想,第一...
摘要:注意这个是的范例是一款基于的常驻内存型高性能框架,框架的高性能特点非常适合开发接口,而且非常接近传统框架,所以开发接口时非常简单。下面做一个开发接口的简单实例从表,通过获取一篇文章。第四步使用测试,如下接口开发与测试完成,是不是很简单呀。 注意:这个是 MixPHP V1 的范例 MixPHP 是一款基于 Swoole 的常驻内存型 PHP 高性能框架,框架的高性能特点非常适合开发 A...
阅读 3669·2021-09-22 15:49
阅读 3272·2021-09-08 09:35
阅读 1407·2019-08-30 15:55
阅读 2262·2019-08-30 15:44
阅读 680·2019-08-29 16:59
阅读 1574·2019-08-29 16:16
阅读 451·2019-08-28 18:06
阅读 875·2019-08-27 10:55