Java常见面试题之RabbitMQ

为什么要使用RabbitMQ

        RabbitMQ是一款非常优秀的消息中间件,它可以实现各个模块之间的松耦合,提高程序的灵活性,可扩展性,使用RabbitMQ主要有以下优点:

  1. 异步消息传递,RabbitMQ支持异步消息传递,可以实现异步处理消息,提高程序的执行效率.
  2. 消息队列排队服务,RabbitMQ可以将消息暂存到消息队列中,有效缓解生产者和消费者的压力.
  3. RabbitMQ支持基于消息的路由机制,发布订阅/机制,工作模式等多重模式,灵活性较高.
  4. RabbitMQ非常容易扩展,对于大数据量或者高并发的程序的帮助非常大.
  5. 可靠性,RabbitMQ有非常可靠的消息确认机制,如:ACK确认机制和消息的持久性等.确保消息不会丢失..

说一下你在项目中使用RabbitMQ的场景

        我们的项目使用RabbitMQ的场景非常多,我也在很多场景使用过RabbitMQ,例如:

        在用户选择调整上课时间之后,会从原直播间的白名删除,再加入到新的直播间白名单中,并且通知对应的分管教师.在这个流程中,最核心的业务功能是从原直播间的白名单中删除,再加入到新的直播间白名单中.其次不是很重要的是通知对应的分管教师.在这个场景下,我们同步完成的业务就是刚才提到的核心业务.在核心业务处理完之后,会从知音楼、教师后台、短信同时通知对应的分管教师.这三个通知我们会使用RabbitMQ进行异步处理,这样可以提高整个业务逻辑功能的执行速度,提高用户体验.这个场景主要也是使用了RabbitMQ的异步处理功能.

        还是上面的例子.由于我们的项目是分布式的项目,各个模块之间是相互独立的,从接受到请求的controller层到service层再到dao层,其实都是一些独立的子项目,在子项目中相互交流,我们会使用RabbitMQ进行消息传递,这样既可以降低各个模块之间的耦合度,也可以确保消息不会丢失.

        而且由于我们的项目要求所有的操作日志都要存放在相应的日志表里,并且同时要落盘到本地的日志文件中,所以为了提高效率,我们会将日志信息存放到RabbitMQ中,由专门负责处理日志的模块去从消息队列中获取消息并处理.这样不会因为处理日志信息导致核心业务的处理效率收到日志处理的影响.

如何确保消息正确的发送到RabbitMQ?如何确保消息接收方接收到了消息

        在使用RabbitMQ时,我们要首先确认程序和RabbitMQ的连接状态和信道状态

        之后就要确保生产者的消息可以到大Exchange,这一环节RabbitMQ是提供了ACK消息确认机制的,当我们开启ACK消息确认机制.消息从生产者发送到交换机,会有一个confirm回调函数,如果交换机正确的接收了方法,ACK为true,如果交换机没有接收到消息,ACK就是false,同时还会返回对应的错误信息.

        要确保消息接收方能够接收到消息,我们要做一下分析,使用RabbitMQ之后,生产者会将消息先发送至Exchange,Exchange再将消息发送到相应的Queue,消费者从Queue中获取消息,其中第一个环节我们已经可以确保它可以发送过去。最后的消费者从Queue获取消息,我们需要检查消费者监听的队列是否正确。

        重点在第二步,从Exchange到Queue,这个环节RabbitMQ提供了Return确认机制,如果消息从Exchange成功到达了Queue,不会执行回调,如果发送失败,就会执行ReturnCallback回调,同时返回消息本体,错误状态码,错误信息,交换机和发生错误的路由。

你可能感兴趣的:(Java常见面试题,java-rabbitmq,rabbitmq,java)