有时候,由于各方面原因比如安全原因.系统间隔离,我们需要实现在多个rabbitmq实例或者一个rabbitmq实例的多个vhost间推送消息.在上一版的实现中,公司使用java自行实现了一个类似转发器的功能,其结构为: 内部MQ->java-pusher->外部MQ 其中在java-pusher的配置文件里面定义内部MQ和外部MQ各队列之间的映射关系.这样做除了额外的开发和维护成本外,一定程度还增加了系统资源的消耗.最近在测试rabbitmq cluster的各种异常恢复时,发现其提供了一个原…
官网说明https://www.rabbitmq.com/shovel.html#management-status 启用shovel插件命令: rabbitmq-plugins enable rabbitmq_shovelrabbitmq-plugins enable rabbitmq_shovel_management 查看已经安装的插件 rabbitmq-plugins list shovel 插件的使用存在 static 和 dynamic 两种形式,其主要差异如下 Static Sho…
前言 生产环境中会遇到RabbitMQ数据迁移的场景,例如:切换云服务厂商.不同Region之间数据迁移.新搭建RabbitMQ实例,数据需要同步至新的RabbitMQ实例. 前提条件: 源RabbitMQ实例打开了shovel插件. 目的RabbitMQ实例打开了shovel插件. 源实例与目的实例能够网络互通. 当前以华为云不同Region下RabbitMQ实例数据迁移为例子.已在华为云北京Region.上海Region各创建一个集群实例.现在需要将上海Region的数据迁移至北京Regio…
到目前为止,我们项目的结果大致如下: 传感器生成的模拟数据(包含传感器名称.数据.时间戳)是通过传感器在运行时动态创建的 Queue 来发送的.这些 Queue 很难直接被发现. 为了解决这个问题,我创建了另一个消息,它包含各传感器的 Queue 的路由 key,这个消息是在一个"众所周知"的 Queue 上发布的,所以协调器就可以得到传感器的路由信息. 传感器的数据是发布在默认的 Direct     Exchange 上,也就是说只有一个消费者可以收到这个消息,这就是我们想要的效果…
package com.study.rabbitmq.a132.confirm; import com.rabbitmq.client.*; import java.io.IOException; import java.util.ArrayList; import java.util.concurrent.TimeoutException; // 可靠生产 // https://www.rabbitmq.com/confirms.html public class Producer { pub…
我这个安装攻略首先得保证服务器上安装过docker了 如果没安装docker请先去安装docker 1.首先说一下什么是MQ MQ(message queue)字面意思上来说消息队列,FIFO先入先出,队列中存入的内容是message,是一种跨进程的通信机制,用于上下游传递消息.MQ 是一种非常常见的上下游"逻辑解耦+物理解耦"的消息通信服务.使用了 MQ 之后,消息发送上游只需要依赖 MQ,不 用依赖其他服务. 1.1为什么要用MQ/MQ有什么用 1.1.1流量消峰 比如说订单系统最…
上一篇博文中,我们使用direct exchange 代替了fanout exchange,这次我们来看下topic exchange. 一.Topic Exchange介绍 topic exchange和direct exchange类似,都是通过routing key和binding key进行匹配,不同的是topic exchange可以为routing key设置多重标准. direct路由器类似于sql语句中的精确查询:topic 路由器有点类似于sql语句中的模糊查询. 还记得吗?我…
前两篇博客介绍了两种队列模式,这篇博客介绍订阅.路由和通配符模式,之所以放在一起介绍,是因为这三种模式都是用了Exchange交换机,消息没有直接发送到队列,而是发送到了交换机,经过队列绑定交换机到达队列. 一.订阅模式(Fanout Exchange): 一个生产者,多个消费者,每一个消费者都有自己的一个队列,生产者没有将消息直接发送到队列,而是发送到了交换机,每个队列绑定交换机,生产者发送的消 息经过交换机,到达队列,实现一个消息被多个消费者获取的目的.需要注意的是,如果将消息发送到一个没有…
此模式下,消息的routing key 和队列的 routing key 会被完全忽略,而是在交换机推送消息和队列绑定交换机时, 分别为消息和队列设置 headers 属性, 通过匹配消息和队列的 header 决定消息的分发. producer.php header('Content-Type: text/html; charset=utf-8'); // 连接设置 $conConfig = [ 'host' => '127.0.0.1', 'port' => 5672, 'login' =…
Topic Exchange 此模式下交换机,在推送消息时, 会根据消息的主题词和队列的主题词决定将消息推送到哪个队列. 交换机只会为 Queue 分发符合其指定的主题的消息. 向交换机发送消息时,消息的 routing key 就是主题关键词,主题词不能随意设置,必须由 "." 联结多个主题词 (如:log.error.log.warn) . 必须将队列显示的绑定到指定的交换机上. 为队列指定队列主题词时,可以使用通配符: "#": 表示 0 或多个主题词; &q…