RabbitMQ面试题有哪些


这篇文章主要介绍RabbitMQ面试题有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!RabbitMQ是消息中间件,采用的erlang语言,而这个语言本身就是支持并发的。在项目中运用的场景是我们的订单数据修改时,需要把订单的状态同步给第三方系统,在这个对接过程,我们将消息发送到RabbitMQ上,而RabbitMQ再把消息推给第三方系统。
几种模式1.单发送单接收2.单发送多接收3.发布订阅模式4.按topic发送接收
如何保证数据不丢失在整个发送消息,消费消息的过程中,可能三个地方存在问题:1.发送时,消息由于网络问题,半路搞丢。解决方法:a.同步。采用事务管理,开启事务,在发送消息的时候,如果mq没有接受到消息,则抛出异常,本地捕获异常并重试。b.异步。写入时可以回调本地接口,确认机制。(建议使用)
2.MQ服务器本身的问题。如果他还没来得及把消息发送消费端就挂了,这个时候消息就丢失了。解决方法:(持久化操作)a.创建队列时,设置其为持久化。b.消息的de 香港云主机liveryMode为2。
3.在消费的时候,消息由于网络问题,半路搞丢。解决方法:消费者在接收到消息先执行业务代码,等结束时,再告诉服务器已经执行完,再执行删除操作。
如何避免数据重复消费这个RabbitMQ认为不是服务器的问题,而是我们的代码问题。所以我们的解决方法是在消费端进行控制,拥有一个业务id,人工去重。以上是“RabbitMQ面试题有哪些”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注开发云行业资讯频道!

相关推荐: Nginx 405 not allowed 异常要怎么办处理

Nginx 405 not allowed 异常要怎么办处理,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。今天遇到一个问题,当配置好的前端工程放到服务器上使用nginx启动的时候,报了405 No…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 10/07 10:51
下一篇 10/07 10:59

相关推荐