0


RabbitMQ如何测试

结合上一篇的遇到bug如何查日志

我们来学习下,如何使用RabbitMQ管理台来测试MQ;

还是之前的例子,用图片简单介绍下逻辑

01 为什么我们要测MQ?什么时候测?

当认证成功之后,没有更新账号的认证状态,涉及到MQ的地方都有可能产生bug:

  • 认证系统没有发MQ;
  • 认证系统发送的MQ数据错误或字段缺失;
  • 账号系统没有消费MQ;
  • 账号系统消费了MQ,但是更新认证状态失败;

除了查询服务器日志之外,MQ后台也可以帮助我们定位MQ问题;

02 RabbitMQ工作原理

在讲解如何查询之前,得先了解下MQ的工作原理:

其中,中间的Broker表示RabbitMQ服务,每个Broker里面至少有一个Virtual host虚拟主机,每个虚拟主机中有自己的Exchange交换机、Queue队列以及Exchange交换机与Queue队列之间的绑定关系Binding。producer(生产者)和consumer(消费者)通过与Broker建立Connection来保持连接,然后在Connection的基础上建立若干Channel信道,用来发送与接收消息。

上面是官方解释,我用小白语言翻译一遍,就是如下图:

03 RabbitMQ管理后台

讲完原理,再看下后台长什么样子:

  • 交换机列表:

  • 交换机详情:

选择一个交换机,可以查看到有哪些路由,哪些队列绑定了哪些路由;

可以新增队列、手动触发发送mq消息;

  • 队列列表:

可以看到队列的堆积情况,及消息处理速度;(如果有堆积,且一直在新增,说明并没有被消费)

可以新增自己的队列,绑定交换机及路由;

  • 队列详情:

04 分析问题

现在要开始分析了:

1、认证MQ发了没?认证系统发送的MQ数据错误或字段缺失;

由于MQ被消费了之后,队列就清空了,如果发送和消费都没问题的话,那账号队列是空的,无法查询到;

这个时候,我们可以新增一个自己的队列,去绑定认证的交换机路由;由于自己新增的队列没有程序去消费,会一直积压,就可以通过自己新增队列查询消息;

如果能查询到消息,说明认证是发送了的;

通过get message而且还可以看到消息内容是否正确,有无字段缺失等;

如果没有发送,那么在常规的测试场景下,就无法测试账号的消费是否有bug,我们可以在交换机详情页,手动推送MQ,去看账号是否变更认证状态;(但是这个时候不好把握MQ的消息格式,得去问开发)

2、账号消费了MQ吗?

这个时候只需要去看账号的队列是否有积压就可以了;

3、账号系统消费了MQ,但是更新认证状态失败;

到这一步在MQ阶段就收尾了,就去查询其他问题了,有没有报错之类的(上篇已讲过);

好了,到此MQ的介绍就已完结;其实关于RabbitMQ管理后台的讲解只是冰山一角,这里只列出了与本文排查有关的,大家可以再多去了解一下~ 欢迎大家一起探讨~

标签: rabbitmq 分布式

本文转载自: https://blog.csdn.net/axing194/article/details/138580454
版权归原作者 axing194 所有, 如有侵权,请联系我们删除。

“RabbitMQ如何测试”的评论:

还没有评论