• RabbitMQ:主题模式


    主题模式

    实际上这种模式就是一种模糊匹配的模式,我们可以将routingKey以模糊匹配的方式去进行转发。

    我们可以使用*#来表示:

    • * - 表示任意的一个单词
    • # - 表示0个或多个单词

    这里我们来测试一下:

    1. @Configuration
    2. public class RabbitConfiguration {
    3. @Bean("topicExchange") //这里使用预置的Topic类型交换机
    4. public Exchange exchange(){
    5. return ExchangeBuilder.topicExchange("amq.topic").build();
    6. }
    7. @Bean("yydsQueue")
    8. public Queue queue(){
    9. return QueueBuilder.nonDurable("yyds").build();
    10. }
    11. @Bean("binding")
    12. public Binding binding2(@Qualifier("topicExchange") Exchange exchange,
    13. @Qualifier("yydsQueue") Queue queue){
    14. return BindingBuilder
    15. .bind(queue)
    16. .to(exchange)
    17. .with("*.test.*")
    18. .noargs();
    19. }
    20. }

    启动项目,可以看到只要是满足通配符条件的都可以成功转发到对应的消息队列:

    接着我们可以再试试看#通配符。

    除了我们这里使用的默认主题交换机之外,还有一个叫做amq.rabbitmq.trace的交换机:

    可以看到它也是topic类型的,那么这个交换机是做什么的呢?实际上这是用于帮助我们记录和追踪生产者和消费者使用消息队列的交换机,它是一个内部的交换机,那么如果使用呢?首先创建一个消息队列用于接收记录:

    接着我们需要在控制台将虚拟主机/test的追踪功能开启:

    sudo rabbitmqctl trace_on -p /test

    开启后,我们将此队列绑定到上面的交换机上:

    由于发送到此交换机上的routingKey为routing key为 publish.交换机名称 和 deliver.队列名称,分别对应生产者投递到交换机的消息,和消费者从队列上获取的消息,因此这里使用#通配符进行绑定。

    现在我们来测试一下,比如还是往yyds队列发送消息:

    可以看到在发送消息,并且消费者已经处理之后,trace队列中新增了两条消息,那么我们来看看都是些什么消息:

    通过追踪,我们可以很明确地得知消息发送的交换机、routingKey、用户等信息,包括信息本身,同样的,消费者在取出数据时也有记录:

    我们可以明确消费者的地址、端口、具体操作的队列以及取出的消息信息等。

    到这里,我们就已经了解了3种类型的交换机。

  • 相关阅读:
    美芯片禁令再次扩大,波及英伟达、AMD以及intel等科技公司 | 百能云芯
    [附源码]计算机毕业设计JAVA企业公开招聘系统
    MyEclipse 下载、安装教程
    【毕业设计】大数据 电影数据分析与可视化系统 - python Django 大数据 可视化
    RestCloud ETL抽取动态库表数据实践
    消防安全知识答题小程序v3.0已迭代完成
    flutter 绘制原理探究
    CocosCreator 面试题(十)Cocos Creator 内存管理
    采集Nginx日志的几种方式
    redis 问题解决 1
  • 原文地址:https://blog.csdn.net/Leon_Jinhai_Sun/article/details/126188956