rabbitMQ学习笔记(六) topic类型消息。

2024-05-04 05:32

本文主要是介绍rabbitMQ学习笔记(六) topic类型消息。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上一节中使用了消息路由,消费者可以选择性的接收消息。 但是这样还是不够灵活。 

比如某个消费者要订阅娱乐新闻消息 。 包括新浪、网易、腾讯的娱乐新闻。那么消费者就需要绑定三次,分别绑定这三个网站的消息类型。 如果新闻门户更多了,那么消费者将要绑定个更多的消息类型, 其实消费者只是需要订阅娱乐新闻,不管是哪个网站的新闻,都需要。 那么在rabbitMQ中可以使用topic类型。 模糊匹配消息类型。

模糊匹配中的 *代表一个  #代表零个或1个

示例:

[java]  view plain copy
  1. package com.zf.rabbitmq06;  
  2.   
  3. import java.io.IOException;  
  4.   
  5. import com.rabbitmq.client.Channel;  
  6. import com.rabbitmq.client.Connection;  
  7. import com.rabbitmq.client.ConnectionFactory;  
  8. import com.rabbitmq.client.ConsumerCancelledException;  
  9. import com.rabbitmq.client.QueueingConsumer;  
  10. import com.rabbitmq.client.QueueingConsumer.Delivery;  
  11. import com.rabbitmq.client.ShutdownSignalException;  
  12.   
  13. /** 
  14.  * 接收消息 
  15.  * @author zhoufeng 
  16.  * 
  17.  */  
  18. public class Recv06_01 {  
  19.   
  20.     public static void main(String[] args) throws IOException, ShutdownSignalException, ConsumerCancelledException, InterruptedException {  
  21.           
  22.         ConnectionFactory connFac = new ConnectionFactory() ;  
  23.           
  24.         connFac.setHost("127.0.0.1");  
  25.           
  26.         Connection conn = connFac.newConnection() ;  
  27.           
  28.         Channel channel = conn.createChannel() ;  
  29.           
  30.           
  31.         String exchangeName = "exchange03";  
  32.           
  33.         channel.exchangeDeclare(exchangeName, "topic") ;  
  34.           
  35.         String queueName = channel.queueDeclare().getQueue() ;  
  36.           
  37.         //第三个参数就是type,这里表示只接收type01类型的消息。  
  38.         channel.queueBind(queueName, exchangeName, "#.type01") ;  
  39.           
  40.           
  41.         //配置好获取消息的方式  
  42.         QueueingConsumer consumer = new QueueingConsumer(channel) ;  
  43.         channel.basicConsume(queueName, true, consumer) ;  
  44.           
  45.         //循环获取消息  
  46.         while(true){  
  47.               
  48.             //获取消息,如果没有消息,这一步将会一直阻塞  
  49.             Delivery delivery = consumer.nextDelivery() ;  
  50.               
  51.             String msg = new String(delivery.getBody()) ;    
  52.               
  53.             System.out.println("received message[" + msg + "] from " + exchangeName);  
  54.         }  
  55.           
  56.     }  
  57.       
  58. }  


[java]  view plain copy
  1. package com.zf.rabbitmq06;  
  2.   
  3. import java.io.IOException;  
  4.   
  5. import com.rabbitmq.client.Channel;  
  6. import com.rabbitmq.client.Connection;  
  7. import com.rabbitmq.client.ConnectionFactory;  
  8.   
  9. /** 
  10.  * 发送消息 
  11.  * @author zhoufeng 
  12.  * 
  13.  */  
  14. public class Sender06 {  
  15.       
  16.     public static void main(String[] args) throws IOException {  
  17.           
  18.         ConnectionFactory connFac = new ConnectionFactory() ;  
  19.           
  20.         //RabbitMQ-Server安装在本机,所以直接用127.0.0.1  
  21.         connFac.setHost("127.0.0.1");  
  22.           
  23.         //创建一个连接  
  24.         Connection conn = connFac.newConnection() ;  
  25.           
  26.         //创建一个渠道  
  27.         Channel channel = conn.createChannel() ;  
  28.           
  29.         String exchangeName = "exchange03";  
  30.           
  31.         String messageType = "fs.type01";  
  32.           
  33.         channel.exchangeDeclare(exchangeName, "topic") ;  
  34.           
  35.         //定义Queue名  
  36.         String msg = "Hello World!";  
  37.           
  38.         //发送消息  
  39.         channel.basicPublish( exchangeName , messageType , null , msg.getBytes());  
  40.           
  41.         System.out.println("send message[" + msg + "] to "+ exchangeName +" success!");  
  42.           
  43.         channel.close();   
  44.         conn.close();   
  45.           
  46.     }  
  47.   
  48. }  

使用topic之后 。不管Sender端发送的消息类型是fs.type01 还是 xx.type01 还是 type01 ,消费者都会收到消息。

转载:http://blog.csdn.net/is_zhoufeng/article/details/10054423

这篇关于rabbitMQ学习笔记(六) topic类型消息。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/958420

相关文章

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Redis消息队列实现异步秒杀功能

《Redis消息队列实现异步秒杀功能》在高并发场景下,为了提高秒杀业务的性能,可将部分工作交给Redis处理,并通过异步方式执行,Redis提供了多种数据结构来实现消息队列,总结三种,本文详细介绍Re... 目录1 Redis消息队列1.1 List 结构1.2 Pub/Sub 模式1.3 Stream 结

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优