2024-04-01  阅读(3)
原文作者:立小言先森 原文地址: https://mingyang.blog.csdn.net/article/details/103652015

rabbitmq_tracing插件相当于Firehose的GUI版本,它同样能跟踪RabbitMQ中消息的流入流出情况。rabbitmq_tracing插件同样会对流入流出的消息进行封装,然后将封装后的日志存入相应的trace文件中。

启动rabbitmq_tracing插件:
    [root@rabbit1 /]# rabbitmq-plugins enable rabbitmq_tracing
    Enabling plugins on node rabbit@rabbit1:
    rabbitmq_tracing
    The following plugins have been configured:
      rabbitmq_management
      rabbitmq_management_agent
      rabbitmq_tracing
      rabbitmq_web_dispatch
    Applying plugin configuration to rabbit@rabbit1...
    The following plugins have been enabled:
      rabbitmq_tracing
    
    started 1 plugins.
对应关闭rabbitmq_tracing插件指令是:
    [root@rabbit1 /]# rabbitmq-plugins disable rabbitmq_tracing
    Disabling plugins on node rabbit@rabbit1:
    rabbitmq_tracing
    The following plugins have been configured:
      rabbitmq_management
      rabbitmq_management_agent
      rabbitmq_web_dispatch
    Applying plugin configuration to rabbit@rabbit1...
    The following plugins have been disabled:
      rabbitmq_tracing
    
    stopped 1 plugins.
启动rabbitmq_tracing插件后,在web管理界面Admin右侧会多出一个Tracing选项:

202404012101081591.png

可以在此Tab项中添加相应的trace,如上图所示;在添加完成trace之后,会根据匹配规则将相应的日志输出到对应的trace文件中,文件的默认路径是/var/tmp/rabbitmq-tracing,可以在页面中直接点击Trace log files查看追踪到的消息,如下图:

202404012101086792.png

我们添加了两个trace任务,与之对应的有两个trace文件,可以通过trace文件追踪消息的流入和流出情况;

队列

在添加完成两个trace任务后,会发现多了两个队列,如下图:

202404012101091023.png

就以第一个队列amq.gen-K1qSTxD4k3z8aLWMEn5Z3w而言,其所绑定的交换器就是amq.rabbitmq.trace,如下图所示:

202404012101094014.png

由此可以看出整个rabbitmq_tracing插件和Firehouse在实现上如出一辙,只不过rabbitmq_tracing插件比Firehouse多了一层GUI的包装,更容易使用和管理。

新增trace时参数含义
  • Name:即将创建的trace的名称

  • Format:表示输出消息日志的格式,有Text和JSON两种,Text格式方便人类阅读,JSON格式方便程序解析

  • Max payload bytes:表示每条消息的最大限制,单位为B。比如设置了此值为10,那么当有超过10B的消息经过RabbitMQ流转时就会被载断,如:trace test payload会被载断成trace test.

  • Pattern用来设置匹配的模式,和Firehose类似,详解如下:

    "publish.#"匹配发送至所有交换器的消息

    “deliver.#"匹配消费所有队列的消息

    “#”包含“publish.#“和“deliver.#”

    "publish.test_exchange"匹配发送到指定交换器的消息

    “deliver.test_queue"匹配消费指定队列的消息

    GitHub地址:https://github.com/mingyang66/spring-parent


Java 面试宝典是大明哥全力打造的 Java 精品面试题,它是一份靠谱、强大、详细、经典的 Java 后端面试宝典。它不仅仅只是一道道面试题,而是一套完整的 Java 知识体系,一套你 Java 知识点的扫盲贴。

它的内容包括:

  • 大厂真题:Java 面试宝典里面的题目都是最近几年的高频的大厂面试真题。
  • 原创内容:Java 面试宝典内容全部都是大明哥原创,内容全面且通俗易懂,回答部分可以直接作为面试回答内容。
  • 持续更新:一次购买,永久有效。大明哥会持续更新 3+ 年,累计更新 1000+,宝典会不断迭代更新,保证最新、最全面。
  • 覆盖全面:本宝典累计更新 1000+,从 Java 入门到 Java 架构的高频面试题,实现 360° 全覆盖。
  • 不止面试:内容包含面试题解析、内容详解、知识扩展,它不仅仅只是一份面试题,更是一套完整的 Java 知识体系。
  • 宝典详情:https://www.yuque.com/chenssy/sike-java/xvlo920axlp7sf4k
  • 宝典总览:https://www.yuque.com/chenssy/sike-java/yogsehzntzgp4ly1
  • 宝典进展:https://www.yuque.com/chenssy/sike-java/en9ned7loo47z5aw

目前 Java 面试宝典累计更新 400+ 道,总字数 42w+。大明哥还在持续更新中,下图是大明哥在 2024-12 月份的更新情况:

想了解详情的小伙伴,扫描下面二维码加大明哥微信【daming091】咨询

同时,大明哥也整理一套目前市面最常见的热点面试题。微信搜[大明哥聊 Java]或扫描下方二维码关注大明哥的原创公众号[大明哥聊 Java] ,回复【面试题】 即可免费领取。

阅读全文