RabbitMQ面试题有哪些

这篇文章主要介绍RabbitMQ面试题有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

成都创新互联公司专注于且末网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供且末营销型网站建设,且末网站制作、且末网页设计、且末网站官网定制、小程序开发服务,打造且末网络公司原创品牌,更为您提供且末网站排名全网营销落地服务。

RabbitMQ是消息中间件,采用的erlang语言,而这个语言本身就是支持并发的。

在项目中运用的场景是我们的订单数据修改时,需要把订单的状态同步给第三方系统,在这个对接过程,我们将消息发送到RabbitMQ上,而RabbitMQ再把消息推给第三方系统。

几种模式


1.单发送单接收

2.单发送多接收

3.发布订阅模式

4.按topic发送接收

如何保证数据不丢失

在整个发送消息,消费消息的过程中,可能三个地方存在问题:

1.发送时,消息由于网络问题,半路搞丢。

解决方法:

  • a.同步。采用事务管理,开启事务,在发送消息的时候,如果mq没有接受到消息,则抛出异常,本地捕获异常并重试。

  • b.异步。写入时可以回调本地接口,确认机制。(建议使用)

2.MQ服务器本身的问题。如果他还没来得及把消息发送消费端就挂了,这个时候消息就丢失了。

解决方法:(持久化操作)

  • a.创建队列时,设置其为持久化。

  • b.消息的deliveryMode为2。

3.在消费的时候,消息由于网络问题,半路搞丢。

解决方法:消费者在接收到消息先执行业务代码,等结束时,再告诉服务器已经执行完,再执行删除操作。

如何避免数据重复消费

这个RabbitMQ认为不是服务器的问题,而是我们的代码问题。

所以我们的解决方法是在消费端进行控制,拥有一个业务id,人工去重。

以上是“RabbitMQ面试题有哪些”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!

文章名称:RabbitMQ面试题有哪些
URL标题:https://www.cdcxhl.com/article4/pgdjoe.html

成都网站建设公司_创新互联,为您提供云服务器品牌网站建设网站营销网站设计公司搜索引擎优化App设计

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

网站建设网站维护公司