博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
消息中间件rabbitmq(3)
阅读量:6852 次
发布时间:2019-06-26

本文共 1803 字,大约阅读时间需要 6 分钟。

介绍

RabbitMq中不存在topic这个概念,不同的消费者想要消费不同的消息只有通过Exchange(交换器)来实现

Exchange类型介绍

注:1. 在针对同一个queue或者exchage时,queueDeclare消费者和生产者所有的配置都必须要保存一致,否则会抛出530的异常。   

       2.Exchange只用于Producer,RoutingKey用来绑定Exchange和Queue,这个一般在Producer这端做的。

      *3. 假如Producer把消息发到没有绑定Queue的Exchange消息会丢失!

direct类型

该类型的是默认的exchage,直接指定消息需要发送的那个队列

Exchage创建

channel.queueDeclare(QUEUE_NAME, false, false, false, null);

发送消息

channel.basicPublish("", QUEUE_NAME, null, message.getBytes("UTF-8"));

接受消息

chanel.queueDeclare(QUEUE_NAME, false, false, false, null);

Topic类型

该类型的exchange可以通过模糊匹配,使一个消费者可以消费多个queue的消息

Exchage创建

//EXCHANGE_NAME创建过后不能修改 第三个参数表示持久化channel.exchangeDeclare(EXCHANGE_NAME, "topic",true); //将队列,转换器,路由规则绑定(下面表示的是吧不同的两个队列绑定到同一个转换器上,但是配置不同的routeKey) channel.queueBind(QUEUE_NAME, EXCHANGE_NAME, "*.second.*"); channel.queueBind(QUEUE_NAME+".v2", EXCHANGE_NAME, "first.second.*");

发送消息

//第二个参数表示routeKey  格式为String.String.String...(根据路由规则匹配,下面这个消息会同时发送到QUEUE_NAME和QUEUE_NAME.v2这两个队列中)channel.basicPublish(EXCHANGE_NAME, "first.second.three", null,message.getBytes());

接受消息

channel.exchangeDeclare(EXCHANGE_NAME, "topic");String queue = channel.queueDeclare().getQueue();//第三个参数表示routeKey,这里不同于生产者,是可以使用* 或者 # 进行模糊匹配,即满足该表达式的queue都可以消费,比如之前设置的first.second.three在这里可以设置成first.*.*或者first.#或者 *.second.*来进行消费channel.queueBind(queue, EXCHANGE_NAME, "first.*.*"); // 声明要关注的队列 channel.queueDeclare(queue, true, false, false, null);

Fanout类型

不处理路由键。你只需要简单的将队列绑定到交换机上。一个发送到该类型交换机的消息都会被广播到与该交换机绑定的所有队列

创建Exchange

channel.exchangeDeclare(EXCHANGE_NAME, "fanout")

发送消息

channel.basicPublish(EXCHANGE_NAME, "", null, message.getBytes());

接受消息

channel.exchangeDeclare(EXCHANGE_NAME, "fanout");String queueName = channel.queueDeclare().getQueue();channel.queueBind(queueName, EXCHANGE_NAME, "");

 

转载于:https://www.cnblogs.com/dengyu/p/10059444.html

你可能感兴趣的文章
深入理解并行编程4
查看>>
Internet Connection speeds
查看>>
puppet运维自动化之puppet模块示例
查看>>
如何让云×××:VIS Creator 带给您一个市场领先的私有云管理平台
查看>>
获取各个ISP运营商IP地址修正版[菜鸟级]
查看>>
python核心编程--第五章
查看>>
我的友情链接
查看>>
关于Mac系统中SequelPro工具对于Mysql数值类型nt(M)存值的bug
查看>>
Linux下重置MySQL的Root帐号密码
查看>>
下一个目标-百度
查看>>
百度地图API学习之路(2)
查看>>
dell服务器硬盘的状态变成外来(foreign)
查看>>
redhat6.4更换centos 6 的 yum源
查看>>
jsquery问题
查看>>
深入了解android平台的jni---编译ffmpeg源码
查看>>
共享JSP部署后测试代码
查看>>
日常订阅的开发工具和服务——2018年
查看>>
linux下乱码问题及解决方式
查看>>
回车和换行有什么区别?很尴尬》》》
查看>>
Hibernate(十六)数据库事务与隔离级别
查看>>