在Java中,可以使用消息队列来实现消息的异步处理,其中常用的消息队列有 RabbitMQ、ActiveMQ、Kafka 等。
什么是幂等性?
幂等性是指无论操作执行多少次,都是得到相同的结果,而不会产生其他副作用。
在rabbitMQ中
什么是消息重复消费?
同一条消息在MQ中被消费多次
出现重复消费的原因:
生产者发送一条消息到rabbitMQ,但rabbitMQ尚未收到消费者的确认,会认为消息消费未被消费而重新发送。
网络不稳定、消费者故障、网络分区、消息重复传递策略、消费者超时设置不当
为什么需要避免重复消费?
业务错误:我本来写的业务逻辑就是只要执行一次
数据重复:数据插入重复,破坏数据唯一性
资源浪费:占用系统资源,降低系统性能
如何避免消息重复消费?
消息去重
通过记录已经消费过的消息,在消息到达时检查它是否已经在记录中存在,从而避免重复处理。
if (!processedMessages.contains(message)) { processMessage(message); processedMessages.add(message); }
消息幂等性
分布式锁(消息幂等性)
使用UUID生成唯一Id ,作为messageId
使用了唯一的消息ID来确保同一条消息只会被处理一次。
AMQP.BasicProperties properties = new AMQP.BasicProperties().builder() .messageId(UUID.randomUUID().toString()) // 唯一标识 .build();
if (!isMessageProcessed(messageId)) { processMessage(message); saveProcessedMessage(messageId); }
消费者先查询该消息是否已经被处理过,如果没有被处理过,则调用processMessage()方法处理该消息,并使用 saveProcessedMessage()方法保存已经处理过的消息。
//手动ack channel.basicAck(message.getMessageProperties().getDeliveryTag(),false
在处理完消息后,还需要调用channel.basicAck(envelope.getDeliveryTag(), false)方法确认消息已经被消费。这是因为RabbitMQ是一个消息的投递机制,只有在消费者确认了消息已经被处理后,才会从消息队列中删除该消息。
使用redis实现避免重复消费
生产者
AMQP.BasicProperties properties = new AMQP.BasicProperties().builder() .deliveryMode(1) // 指定消息是否需要持久化 1-需要 2-不需要 .messageId(UUID.randomUUID().toString()) // 唯一标识 .build();
消费者
String result = jedis.set(messageId, "0", "NX", "EX", 10); if (result != null && result.equalsIgnoreCase("OK")){ System.out.println("接收到消息:"+ new String(body,"UTF-8")); //消费成功 set messageId - 1 jedis.set(messageId,"1"); channel.basicAck(envelope.getDeliveryTag(),false); }else { //如果1中的setnx失败,获取key对应的value,如果是1,设置ack 如果是0 return String s = jedis.get(messageId); if ("1".equalsIgnoreCase(s)){ //消费完了 channel.basicAck(envelope.getDeliveryTag(),false); } }
spring-boot
如果存在,设置value为1;如果value是1,ack
事务性消费
消费状态追踪
猜你喜欢
- 18天前(中旅酒店 维景)中旅酒店首次AI数字人直播亮相南京维景
- 18天前(安徽民航君澜大饭店装饰设计招标)集东方文化气息,品徽派隽美风韵----安徽民航君澜大饭店静待绽放
- 18天前(哥伦比亚号邮轮)爱达邮轮与哥仑比亚船舶管理集团达成合作
- 18天前(兵团猛进秦剧团持续开展“戏曲进校园”活动)兵团猛进秦剧团持续开展“戏曲进校园”活动
- 18天前(重庆恐龙化石遗址)重庆黔江恐龙化石抢救性发掘新闻发布会举行
- 18天前(新西兰“空降”上海:新西兰旅游局邀请你来“玩真的”!)新西兰“空降”上海:新西兰旅游局邀请你来“玩真的”!
- 18天前(071 圣安东尼奥)秋季 圣安东尼奥交出了私藏活动清单
- 18天前(澳涞山庄见证北欧零碳到中国实践,世界十佳环境保护城市榜单发布)澳涞山庄见证北欧零碳到中国实践,世界十佳环境保护城市榜单发布
- 18天前(夏日纵享 邂逅双面姑苏是哪一集)夏日纵享 邂逅双面姑苏
- 18天前(世茂海峡大厦多高)巴西地产高管齐聚厦门世茂海峡大厦 共探超高层建筑锻造经验
网友评论
- 搜索
- 最新文章
- (2020广州车展哈弗)你的猛龙 独一无二 哈弗猛龙广州车展闪耀登场
- (哈弗新能源suv2019款)智能科技颠覆出行体验 哈弗重塑新能源越野SUV价值认知
- (2021款全新哈弗h5自动四驱报价)新哈弗H5再赴保障之旅,无惧冰雪护航哈弗全民电四驱挑战赛
- (海南航空现况怎样)用一场直播找到市场扩张新渠道,海南航空做对了什么?
- (visa jcb 日本)优惠面面俱到 JCB信用卡邀您畅玩日本冰雪季
- (第三届“堡里有年味·回村过大年”民俗花灯会活动)第三届“堡里有年味·回村过大年”民俗花灯会活动
- (展示非遗魅力 长安启源助力铜梁龙舞出征)展示非遗魅力 长安启源助力铜梁龙舞出征
- (阿斯塔纳航空公司)阿斯塔纳航空机队飞机数量增至50架
- (北京香港航班动态查询)香港快运航空北京大兴新航线今日首航
- (我在港航“呵护”飞机 每一次安全着陆就是最好的荣誉)我在港航“呵护”飞机 每一次安全着陆就是最好的荣誉
- 热门文章