swoole coroutine协程消息队列

2024-09-05 08:08

本文主要是介绍swoole coroutine协程消息队列,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先测试一个消息队列的例子:

use Swoole\Coroutine as co;$channel = new co\Channel(100);co::create(function() use($channel){for($i = 0; $i < 20; $i++) {co::sleep(1.0);$channel->push(['key'=>$i,'value'=>rand(111111,999999)]); //数组echo "$i\n";}
});var_dump($channel->length());swoole_event::wait()

演示结果:

可以看到,程序先返回的是消息队列的数量,我看官方这个例子下面有人提问说为什么队列数量一直是0,看到这个显示结果应该明白了,程序是执行到协程代码的地方直接返回结果,然后在执行协程里面的代码,就如上图所示。那怎么能查询到当前内存中消息队列的数量呢,我想有两种方法,一种在添加消息队列过后直接查询数量,第二种在服务器中使用消息队列,服务器没有关闭之前,只要消息队列里面的消息没有被消费,就可以查询到消息队列的数量和状态。估计要使用协程服务器才可以。

第一种代码很简单,在echo "$i\n"; 的后面加上 var_dump($channel->length()); 插入一条,显示一下消息队列的数量。下面是第二种方法:

use Swoole\Coroutine as co;$channel = new co\Channel(100);go(function () use($channel){$server = new Co\Http\Server("127.0.0.1", 8888, false);$server->handle('/', function ($request, $response) use($channel,$server){if(strpos($request->server['request_uri'],'.ico') !== false){$response->end("");}else{echo "开始创建消息队列,推入10个消息".PHP_EOL;co::create(function() use($channel){for($i = 0; $i < 10; $i++) {$channel->push(['key'=>$i,'value'=>rand(111111,999999)]); //数组}});$response->header("Content-Type","text/html; charset=UTF-8");$response->end("<h1>创建了".$channel->length()."消息</h1>");}});$server->handle('/test', function ($request, $response) use($channel,$server){if(strpos($request->server['request_uri'],'.ico') !== false){$response->end("");}else{echo "查看消息队列".PHP_EOL;;$response->header("Content-Type","text/html; charset=UTF-8");$response->end("<h1>查看消息的个数:".$channel->length()."</h1>");}});$server->handle('/stop', function ($request, $response) use ($channel,$server) {if(strpos($request->server['request_uri'],'.ico') !== false){$response->end("");}else{$response->header("Content-Type","text/html; charset=UTF-8");$response->end("<h1>消费一个消息:".json_encode($channel->pop())."</h1>");//$server->shutdown();}});$server->start();
});

演示结果如下:

每次添加10个消息,查看队列数量。消费一个消息,当添加到100消息的时候,后面添加的消息阻塞在队列之外,等待消费者消费消息在100以下,后面的消息才能入队。不然会一直阻塞等待在队列之外等待入队。

以上就是消息队列的简单例子,感觉用起来有点单一,难道整个服务器启动之后就只能创建以个数为名字的消息队列吗?我创建两个消息队列相互影响吗? 还需要继续探究一下。

 

 

 

 

 

 

这篇关于swoole coroutine协程消息队列的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1138403

相关文章

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

Redis消息队列实现异步秒杀功能

《Redis消息队列实现异步秒杀功能》在高并发场景下,为了提高秒杀业务的性能,可将部分工作交给Redis处理,并通过异步方式执行,Redis提供了多种数据结构来实现消息队列,总结三种,本文详细介绍Re... 目录1 Redis消息队列1.1 List 结构1.2 Pub/Sub 模式1.3 Stream 结

SpringKafka错误处理(重试机制与死信队列)

《SpringKafka错误处理(重试机制与死信队列)》SpringKafka提供了全面的错误处理机制,通过灵活的重试策略和死信队列处理,下面就来介绍一下,具有一定的参考价值,感兴趣的可以了解一下... 目录引言一、Spring Kafka错误处理基础二、配置重试机制三、死信队列实现四、特定异常的处理策略五

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优

SpringIntegration消息路由之Router的条件路由与过滤功能

《SpringIntegration消息路由之Router的条件路由与过滤功能》本文详细介绍了Router的基础概念、条件路由实现、基于消息头的路由、动态路由与路由表、消息过滤与选择性路由以及错误处理... 目录引言一、Router基础概念二、条件路由实现三、基于消息头的路由四、动态路由与路由表五、消息过滤

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

Spring Boot整合消息队列RabbitMQ的实现示例

《SpringBoot整合消息队列RabbitMQ的实现示例》本文主要介绍了SpringBoot整合消息队列RabbitMQ的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录RabbitMQ 简介与安装1. RabbitMQ 简介2. RabbitMQ 安装Spring

springboot rocketmq配置生产者和消息者的步骤

《springbootrocketmq配置生产者和消息者的步骤》本文介绍了如何在SpringBoot中集成RocketMQ,包括添加依赖、配置application.yml、创建生产者和消费者,并展... 目录1. 添加依赖2. 配置application.yml3. 创建生产者4. 创建消费者5. 使用在

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque