热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

消息中间件rabbitmq(3)

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

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



推荐阅读
  • 协程作为一种并发设计模式,能有效简化Android平台上的异步代码处理。自Kotlin 1.3版本引入协程以来,这一特性基于其他语言的成熟理念,为开发者提供了新的工具,以增强应用的响应性和效率。 ... [详细]
  • 基于SSM框架的在线考试系统:随机组卷功能详解
    本文深入探讨了基于SSM(Spring, Spring MVC, MyBatis)框架构建的在线考试系统中,随机组卷功能的设计与实现方法。 ... [详细]
  • JUC并发编程——线程的基本方法使用
    目录一、线程名称设置和获取二、线程的sleep()三、线程的interrupt四、join()五、yield()六、wait(),notify(),notifyAll( ... [详细]
  • SDWebImage第三方库学习
    1、基本使用方法异步下载并缓存-(void)sd_setImageWithURL:(nullableNSURL*)urlNS_REFINED_FOR_SWIFT;使用占位图片& ... [详细]
  • 本文探讨了互联网服务提供商(ISP)如何可能篡改或插入用户请求的数据流,并提供了有效的技术手段来防止此类劫持行为,确保网络环境的安全与纯净。 ... [详细]
  • 数据输入验证与控件绑定方法
    本文提供了多种数据输入验证函数及控件绑定方法的实现代码,包括电话号码、数字、传真、邮政编码、电子邮件和网址的验证,以及报表绑定和自动编号等功能。 ... [详细]
  • 本文详细介绍了 Redis 中的主要数据类型,包括 String、Hash、List、Set、ZSet、Geo 和 HyperLogLog,并提供了每种类型的基本操作命令和应用场景。 ... [详细]
  • Beetl是一款先进的Java模板引擎,以其丰富的功能、直观的语法、卓越的性能和易于维护的特点著称。它不仅适用于高响应需求的大型网站,也适合功能复杂的CMS管理系统,提供了一种全新的模板开发体验。 ... [详细]
  • 流处理中的计数挑战与解决方案
    本文探讨了在流处理中进行计数的各种技术和挑战,并基于作者在2016年圣何塞举行的Hadoop World大会上的演讲进行了深入分析。文章不仅介绍了传统批处理和Lambda架构的局限性,还详细探讨了流处理架构的优势及其在现代大数据应用中的重要作用。 ... [详细]
  • 本文将深入探讨 Unreal Engine 4 (UE4) 中的距离场技术,包括其原理、实现细节以及在渲染中的应用。距离场技术在现代游戏引擎中用于提高光照和阴影的效果,尤其是在处理复杂几何形状时。文章将结合具体代码示例,帮助读者更好地理解和应用这一技术。 ... [详细]
  • 深入探讨:Actor模型如何解决并发与分布式计算难题
    在现代软件开发中,高并发和分布式系统的设计面临着诸多挑战。本文基于Akka最新文档,详细探讨了Actor模型如何有效地解决这些挑战,并提供了对并发和分布式计算的新视角。 ... [详细]
  • Flutter 核心技术与混合开发模式深入解析
    本文深入探讨了 Flutter 的核心技术,特别是其混合开发模式,包括统一管理模式和三端分离模式,以及混合栈原理。通过对比不同模式的优缺点,帮助开发者选择最适合项目的混合开发策略。 ... [详细]
  • 本文详细介绍了二叉堆的概念及其在Java中的实现方法。二叉堆是一种特殊的完全二叉树,具有堆性质,常用于实现优先队列。 ... [详细]
  • RTThread线程间通信
    线程中通信在裸机编程中,经常会使用全局变量进行功能间的通信,如某些功能可能由于一些操作而改变全局变量的值,另一个功能对此全局变量进行读取& ... [详细]
  • Redis:缓存与内存数据库详解
    本文介绍了数据库的基本分类,重点探讨了关系型与非关系型数据库的区别,并详细解析了Redis作为非关系型数据库的特点、工作模式、优点及持久化机制。 ... [详细]
author-avatar
求学lx
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有