返回顶部
首页 > 资讯 > 精选 >Swoole怎么通过聚合请求高效实现业务
  • 233
分享到

Swoole怎么通过聚合请求高效实现业务

2023-06-30 14:06:07 233人浏览 安东尼
摘要

这篇文章主要介绍“Swoole怎么通过聚合请求高效实现业务”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Swoole怎么通过聚合请求高效实现业务”文章能帮助大家解决问题。本示例选取的背景是并发下单业

这篇文章主要介绍“Swoole怎么通过聚合请求高效实现业务”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Swoole怎么通过聚合请求高效实现业务”文章能帮助大家解决问题。

本示例选取的背景是并发下单业务。常规情况下,后端创建订单是逐条 insert 的操作。在并发较低的时候,数据库insert 操作的确能保持不错的效率,但是当遇到请求数量增多,数据库 频繁地单次 insert 就会让下单业务整体效率变低 (本文简单地假设1次下单=1个 insert

通过上面的描述,其实已经很容易想到需要优化的地方了。类比现实生活中乘坐电梯的场景:一架电梯 装满后再上行,可以最快地缓解人流压力。

下面我们就来用代码简单实现一下我们思路:

<?PHPSwoole\Runtime::enableCoroutine($flags = SWOOLE_HOOK_ALL);// 最大等待次数const MAX_TIMES = 10;// 按批处理时, 每一批的最大请求暂留数量const MAX_REQUEST = 3;// 服务端最大超时时间, 避免客户端一直等待const MAX_TIMEOUT = 5;Co\run(function () {    // 请求传输的channel, 原因是不要在swoole的协程环境中, 使用多个协程修改同一个全局变量    // 如果是golang, 当然是可以不定义这里的$rqChannel    // 只需要简单的将下面的$rqQueue和$times定义为全局变量即可达到一样的效果    // 但是最好的方式任然是是通过channel共享内存    $rqChannel = new Swoole\Coroutine\Channel(MAX_REQUEST);    // 模拟创建订单    $createOrder = function () use ($rqChannel) {        // 使用数组模拟请求暂留队列        $rqQueue = [];        // 使用等待次数模拟tick效果        $times = MAX_TIMES;        while (true) {            $times--;            // 必须带上timeout参数, 否则channel是阻塞的            $rq = $rqChannel->pop(1);            // 保存1个正常的请求数据            if (!empty($rq)) {                $rqQueue[] = $rq;            }            // 请求数量未达上限或者还有等待次数时, 提前进入下一次循环            if ($times > 0 && count($rqQueue) < MAX_REQUEST) {                continue;            }            // 重置等待次数            $times = MAX_TIMES;            // 初始化sql            $sql = "INSERT INTO orders VALUES ";            $inserts = [];            // 模拟数据验证            $validator = function ($input): bool {                // 为了缩减代码, 没有真的做数据验证的处理                array_filter($input);                return true;            };            // $rqQueue在协程上下文是并发安全的, 所以遍历时不用担心            foreach ($rqQueue as $index => $rq) {                list($data, $chan) = $rq;                // 这里可以考虑后置执行, 原因是后面可以有一些补救逻辑                unset($rqQueue[$index]);                // 判断$chan是否关闭å                if ($chan->errCode === SWOOLE_CHANNEL_CLOSED) {                    $data = null;                    continue;                }                $bool = $validator($data);                if ($bool) {                    $inserts[] = "({$data['user_name']}, {$data['amount']}, {$data['mobile']})";                    $chan->push(['state' => 1]);                } else {                    $chan->push(['state' => 0]);                }                // unset($rqQueue[$index]);            }            $sql .= (implode(',', $inserts) . ';');            // 模拟创建订单落库的逻辑            echo $sql;        }    };    // 新手要注意这一句代码的位置, 原因是 $server->start() 之后的代码不会执行    Go($createOrder);    // 路由处理器    $orderHandler = function ($rq, $res) use ($rqChannel) {        $chan = new Swoole\Coroutine\Channel(1);        // 使用timeout参数模拟超时        $bool = $rqChannel->push([$rq->post, $chan], MAX_TIMEOUT);        if (!$bool) {            // 关闭$chan            $chan->close();            $res->end('timeout');        }        if (!empty($data = $chan->pop())) {            // 关闭$chan            $chan->close();            // 区分成功或失败状态再输出响应            if ($data['state'] === 1) {                $res->end(microtime());            } else {                $res->end('error');            }        }    };    $server = new Co\Http\Server("0.0.0.0", 9502, false);    $server->handle('/order/create', $orderHandler);    // 当前协程容器的终点    $server->start();});

代码整体上还是很容易理解的,变量 $rqQueue 就是类比电梯,暂留请求等待一定时间的次数 $times 就是类比电梯需要等待人流依次进入。当然最在希望读者注意的一点是:在协程环境下,不要使用共享内存而通信,应该使用通信来共享内存

关于“Swoole怎么通过聚合请求高效实现业务”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: Swoole怎么通过聚合请求高效实现业务

本文链接: https://lsjlt.com/news/329511.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Swoole怎么通过聚合请求高效实现业务
    这篇文章主要介绍“Swoole怎么通过聚合请求高效实现业务”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Swoole怎么通过聚合请求高效实现业务”文章能帮助大家解决问题。本示例选取的背景是并发下单业...
    99+
    2023-06-30
  • 怎么通过业务组件提效
    本篇内容介绍了“怎么通过业务组件提效”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、前言无论是在前端刀耕...
    99+
    2024-04-02
  • Grafana中怎么实现数据过滤和聚合
    在Grafana中实现数据过滤和聚合可以通过查询语句和面板设置来实现。以下是一些常见的方法: 使用查询语句中的WHERE...
    99+
    2024-04-02
  • Filter怎么利用http请求实现绕过
    Filter怎么利用http请求实现绕过?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。http请求绕过Filter的实例场景:两个web服务器,A当做服务端,B...
    99+
    2023-05-31
    http filter
  • 泛圈科技:电子制造业如何通过企业云盘从而实现高效的工作效率?
    随着中国进入全面建设小康社会的历史时期,人们的消费水平进入了新的提升阶段,社会对电子信息产品的需求将大大增加,这将有力地推动电子信息产业的发展,电气元件制造业的发展也具有广阔的前景。随着科学技术的飞速发展,电子元件技术也在不断发展,新的电子...
    99+
    2023-06-05
  • 普通企业怎么选择合适的高防服务器
    选择合适的高防服务器要注意的方面:1. 注意高防服务器的机房的配置以及其资质。2.  注意高防服务器的线路类型。3. 注意高防服务器的的防御能力,防御的大小选择要密切衡量自己的成本和日常被攻击的情况。4.注意高防服务器的带宽大小,...
    99+
    2024-04-02
  • SpringBoot中怎么通过整合Redis实现管道
    这篇文章给大家介绍SpringBoot中怎么通过整合Redis实现管道,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1. Redis 之管道(pipeline)执行一个Redis命令,Redis客户端和Redis服务器...
    99+
    2023-06-20
  • react中axios怎么结合后端实现GET和POST请求
    这篇文章主要讲解了“react中axios怎么结合后端实现GET和POST请求”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“react中axios怎么结合后端实现GET和POST请求”吧!r...
    99+
    2023-07-05
  • CentOS7.4上怎么通过keepalive实现Tomcat高可用
    这篇文章主要介绍“CentOS7.4上怎么通过keepalive实现Tomcat高可用”,在日常操作中,相信很多人在CentOS7.4上怎么通过keepalive实现Tomcat高可用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作...
    99+
    2023-06-04
  • SpringBoot2 高级应用(14): 整合 Drools规则引擎,实现高效的业务规则
    本文源码:GitHub·点这里 || GitEE·点这里一、Drools引擎简介1、基础简介Drools是一个基于java的规则引擎,开源的,可以将复杂多变的规则从硬编码中解放出来,以规则脚本的形式存放在文件中,使得规则的变更不需要修正代...
    99+
    2023-06-02
  • 怎么通过docker和docker-compose实现eureka高可用
    这篇文章主要介绍“怎么通过docker和docker-compose实现eureka高可用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么通过docker和doc...
    99+
    2024-04-02
  • springboot怎么通过spel结合aop实现动态传参
    这篇文章主要介绍了springboot怎么通过spel结合aop实现动态传参的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇springboot怎么通过spel结合aop实现动态传参文章都会有所收获,下面我们一起...
    99+
    2023-07-06
  • Android中怎么通过自定义view实现TopBar效果
    这篇文章给大家介绍Android中怎么通过自定义view实现TopBar效果,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。布局文件<xml version="1.0" en...
    99+
    2023-05-30
    android view topbar
  • jQuery怎么通过Ajax向PHP服务端发送请求并返回JSON数据
    这篇文章主要介绍“jQuery怎么通过Ajax向PHP服务端发送请求并返回JSON数据”,在日常操作中,相信很多人在jQuery怎么通过Ajax向PHP服务端发送请求并返回JSON数据问题上存在疑惑,小编查...
    99+
    2024-04-02
  • PLC通过智能网关,实现HTTP协议的POST/GET请求,与服务端JSON格式双向通讯
            智能网关IGT-DSER集成了多种PLC的原厂协议,方便实现各种PLC与服务端之间的HTTP协议通讯,通过网关的参数配置软件绑定JSON文件的字段与PLC寄存器地址,配置URL,即可通过POST/GET命令,将JSON文件提...
    99+
    2023-09-02
    http json 网络协议 lua 数据库
  • Springboot怎么通过Scheduled实现定时任务
    小编给大家分享一下Springboot怎么通过Scheduled实现定时任务,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!定时任务一般会存在中大型企业级项目中,为...
    99+
    2023-05-30
    springboot
  • vue通过v-show怎么实现回到顶部top效果
    这篇文章主要介绍“vue通过v-show怎么实现回到顶部top效果”,在日常操作中,相信很多人在vue通过v-show怎么实现回到顶部top效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue通过v-sh...
    99+
    2023-06-22
  • 如何高效禁用windows8屏幕触摸键盘(通过停用服务实现)
    除非我不需要它或不想看到它。我有一台Lenovo X1 Carbon Touch,并且它已经有一个键盘。我从来都没想要用Windows8触摸键盘。不幸的是没有复选框或者“只是把它关掉&ldquo...
    99+
    2022-06-04
    高效 键盘 屏幕
  • css怎么实现鼠标滑过五角星高亮效果
    这篇文章主要讲解了“css怎么实现鼠标滑过五角星高亮效果 ”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“css怎么实现鼠标滑过五角星高亮效果 ”吧! ...
    99+
    2024-04-02
  • Android中怎么通过自定义RecyclerView控件实现Gallery效果
    这期内容当中小编将会给大家带来有关Android中怎么通过自定义RecyclerView控件实现Gallery效果,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1、RecyclerView的基本用法首先主...
    99+
    2023-05-30
    android recyclerview gallery
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作