2024-04-01
原文作者:立小言先森 原文地址: 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

阅读全文