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

相关文章

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

Android协程高级用法大全

《Android协程高级用法大全》这篇文章给大家介绍Android协程高级用法大全,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友跟随小编一起学习吧... 目录1️⃣ 协程作用域(CoroutineScope)与生命周期绑定Activity/Fragment 中手

聊聊springboot中如何自定义消息转换器

《聊聊springboot中如何自定义消息转换器》SpringBoot通过HttpMessageConverter处理HTTP数据转换,支持多种媒体类型,接下来通过本文给大家介绍springboot中... 目录核心接口springboot默认提供的转换器如何自定义消息转换器Spring Boot 中的消息

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,

java向微信服务号发送消息的完整步骤实例

《java向微信服务号发送消息的完整步骤实例》:本文主要介绍java向微信服务号发送消息的相关资料,包括申请测试号获取appID/appsecret、关注公众号获取openID、配置消息模板及代码... 目录步骤1. 申请测试系统2. 公众号账号信息3. 关注测试号二维码4. 消息模板接口5. Java测试

Java中常见队列举例详解(非线程安全)

《Java中常见队列举例详解(非线程安全)》队列用于模拟队列这种数据结构,队列通常是指先进先出的容器,:本文主要介绍Java中常见队列(非线程安全)的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一.队列定义 二.常见接口 三.常见实现类3.1 ArrayDeque3.1.1 实现原理3.1.2

C++ RabbitMq消息队列组件详解

《C++RabbitMq消息队列组件详解》:本文主要介绍C++RabbitMq消息队列组件的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. RabbitMq介绍2. 安装RabbitMQ3. 安装 RabbitMQ 的 C++客户端库4. A

golang实现延迟队列(delay queue)的两种实现

《golang实现延迟队列(delayqueue)的两种实现》本文主要介绍了golang实现延迟队列(delayqueue)的两种实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录1 延迟队列:邮件提醒、订单自动取消2 实现2.1 simplChina编程e简单版:go自带的time

SpringCloud整合MQ实现消息总线服务方式

《SpringCloud整合MQ实现消息总线服务方式》:本文主要介绍SpringCloud整合MQ实现消息总线服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、背景介绍二、方案实践三、升级版总结一、背景介绍每当修改配置文件内容,如果需要客户端也同步更新,

Python多进程、多线程、协程典型示例解析(最新推荐)

《Python多进程、多线程、协程典型示例解析(最新推荐)》:本文主要介绍Python多进程、多线程、协程典型示例解析(最新推荐),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 目录一、multiprocessing(多进程)1. 模块简介2. 案例详解:并行计算平方和3. 实现逻