RabbitMQ面试题

概念

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

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

几种模式

1.单发送单接收

2.单发送多接收

3.发布订阅模式

4.按topic发送接收

如何保证数据不丢失

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

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

解决方法:

  • a.同步。采用事务管理,开启事务,在发送消息的时候,如果mq没有接受到消息,则抛出异常,本地捕获异常并重试。
  • b.异步。写入时可以回调本地接口,确认机制。(建议使用)

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

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

  • a.创建队列时,设置其为持久化。
  • b.消息的deliveryMode为2。

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

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

如何避免数据重复消费

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

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

本文分享自微信公众号 - 学习Java的小姐姐(huangtest01),作者:学习Java的小姐姐

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-04-09

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Redis系列——6.复制功能

    言归正传,今天要说的可是个大家伙,毕竟从现在开始,咱不整简单功能啦,整点厉害的,哈哈哈

    陈琛
  • String底层实现——动态字符串SDS

    上篇我们已经了解了Redis是什么,在Linux上如何安装,常见的数据类型和API使用,如果有不明白的,可以移步到主页。

    陈琛
  • MongDB进阶系列——2.Windows搭建复制集

    上篇,我们已经知道了什么是MongoDB的复制集,不知道的可以查看上篇哦,传送门来了。

    陈琛
  • Visual Studio Code v0.9.1 发布

    微软的跨平台编辑器 Visual Studio Code v0.9.1 已经发布,官方博客上发布文章Visual Studio Code – October U...

    张善友
  • 服务器安装SG11扩展多版本详细教程说明

    01.首先下载  sg_Loaders.zip 解压都得到一堆文件,对应你自己的服务器,windows,Linux等,这里我们以windows为例,打开Win...

    空木白博客
  • 从5月11号网易被攻击谈起:新型DDoS攻击LFA

    5月11日晚上9时许,网易的大量用户发现访问网易新闻出现问题,相应的,有很多游戏用户报告说游戏掉线严重。一时间,有关“网易大楼着火”的谣传甚嚣。晚上9点42分的...

    FB客服
  • Are you kidding?灯泡也能机器学习?

    智能灯泡已经是非常常见的自动化家居产品,它们的好处是当你不想走到开关前时,可以通过手机开关灯。

    MCU起航
  • 环境实时同步,这点我只服Jeep自由光的VR试驾

    VRPinea
  • 帝国的黄昏(3):SQL是世界上最牛逼的语言

    关系代数诞生于1969年,甲骨文诞生于1978年。这期间的历史很漫长,所以本系列文章等甲骨文上场起码还有好几个章节。

    数据猿
  • 帝国的黄昏(2):SQL是世界上最牛逼的语言

    关系代数诞生于1969年,甲骨文诞生于1978年。这期间的历史很漫长,所以本系列文章等甲骨文上场起码还有好几个章节。

    用户1564362

扫码关注云+社区

领取腾讯云代金券