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

相关文章

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. 实现逻

一文带你搞懂Redis Stream的6种消息处理模式

《一文带你搞懂RedisStream的6种消息处理模式》Redis5.0版本引入的Stream数据类型,为Redis生态带来了强大而灵活的消息队列功能,本文将为大家详细介绍RedisStream的6... 目录1. 简单消费模式(Simple Consumption)基本概念核心命令实现示例使用场景优缺点2

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基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优