RabbitMQ由于默认是基于AMQP协议 , php需要安装一下AMQP才能对RabbitMQ进行操作
由于swoft是基于swoole实现的框架 , swoole无法在windows使用 , 所以需要安装一套linux的环境 , 不会安装的找我的博客(Linux配置RabbitMQ)或自行百度
PHP安装AMQP客户端composer require php-amqplib/php-amqplib
处理数据必读
使用了swoft自定义进程 , 并在bean.php中加载 , 不懂可自行百度或看我之前的文章(Swoft2.X 使用进程处理Redis队列_苗先生的PHP记录的博客-CSDN博客)
topic和fanout 都可不通过queue进行发送 , 也就是声明一个交换机,直接发送数据,详见我的topic的demo
这样子处理数据的时候只需要创建一个空名的queue, 通过routingkey读取数据
- direct:路由模式 , 如果 routing key 匹配,那么 Message 就会被传递到相应的 queue , 如果没有处理的数据是会阻塞在这里等待消费
- fanout:订阅模式 ,会向响应的 queue 广播 , 订阅模式是没有路由键routing_key的
- topic:主题模式 , 通过路由键# 获取所有, *获取部分, 对 key 进行模式匹配,比如 ab* 可以传递到所有 ab* 的 queue
- dlx: 死信队列 (延时队列) ,消息变成死信有以下几种情况
消息被拒绝(basic.reject / basic.nack),并且requeue = false
消息TTL过期
队列达到最大长度
direct路由模式(简单队列) 发送数据控制器:
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?