RabbitMQ学习笔记:消息追踪rabbitmq_tracing插件

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选项:

在这里插入图片描述

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

在这里插入图片描述

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

队列

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

在这里插入图片描述

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

在这里插入图片描述

由此可以看出整个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/tree/master/spring-boot-control-rabbitmq-service

发布了470 篇原创文章 · 获赞 236 · 访问量 142万+

猜你喜欢

转载自blog.csdn.net/yaomingyang/article/details/103652015