ListenerExecutionFailedException消费rabbitMQ队列中消息出错导致刷屏

阅读: 评论:0

ListenerExecutionFailedException消费rabbitMQ队列中消息出错导致刷屏

ListenerExecutionFailedException消费rabbitMQ队列中消息出错导致刷屏

org.springframework.amqp.rabbit.support.ListenerExecutionFailedException: Listener method 'public iver(der.OrderMqVo,org.Message,com.rabbitmq.client.Ch

错误类型:org.springframework.amqp.rabbit.support.ListenerExecutionFailedException

annel) throws java.io.IOException' threw exception

在做一个尚医通项目时,需要用rabbitMQ处理用户的订单消息。然后就出现了刷屏,网上找了一些方法,都没法解决。研究了一段时间,解决了。下面是我的解决办法:

首先我的错误出现的原因是消息接受器无法处理队列中的消息,导致队列中消息无法被消费,接收器又一直去消费,陷入了死循环,导致了刷屏。

 解决办法. 修改两个地方的BUG

1.HospitalReceiver 中的receiver方法

//错误代码
Schedule schedule = ScheduleId());
产生原因: .getScheduleId 
课件上两次更新操作用的同一个方法根据scheduleId查,但是预约下单更新里的scheduleId是前端传过来的值,那个对应mongodb里的字段是_id;取消预约更新里的scheduleId是我们根据mysql查询科室查出来的排班id,对应mongodb里的字段是hosScheduleId;那都1用repository.findById(id).get();后者就会查不到数据,而Optionl没有经过ofNullable()就获取对象,如果对象为空的就会报错。
mq为什么循环报错这个有解释:

https//blog.csdn/lCSDNkingdoml/article/details/120425567:

解决方法:

1.HospitalReceiver 中的receiver方法

//订单消费者!
@RabbitListener(bindings = @QueueBinding(value = @Queue(value = MqConst.QUEUE_ORDER, durable = "true"),exchange = @Exchange(value = MqConst.EXCHANGE_DIRECT_ORDER),key = {MqConst.ROUTING_ORDER}
))
public void receiver(OrderMqVo orderMqVo, Message message, Channel channel) throws IOException {// 如果orderMqVo 为空则,不进行任何操作if(orderMqVo == null){return;}if(null != AvailableNumber()) {//下单成功更新预约数Schedule schedule = ScheduleId());schedule.ReservedNumber());schedule.AvailableNumber());scheduleService.updateSchedule(schedule);//预约成功发送预约成功的短信通知MsmVo msmVo = MsmVo();if(null != msmVo) {//短信消息生成者! 生成短信信息到消息队列rabbitService.sendMessage(MqConst.EXCHANGE_DIRECT_MSM, MqConst.ROUTING_MSM_ITEM, msmVo);}} else {//取消预约更新预约数Schedule schedule = ScheduleId());int availableNumber = AvailableNumber().intValue() + 1;schedule.setAvailableNumber(availableNumber);scheduleService.updateSchedule(schedule);//取消预约可以做专门发送取消预约的短信通知,这里就不做了!}
}

1.2. 添加OrderServiceImple

// 根据排班的 hosScheduleId ,获取排班的详情
@Overridepublic Schedule getScheduleReceiver(String hosScheduleId) {//会导致 取消预约更新预约数MQ刷屏报错Schedule schedule = ScheduleByHosScheduleId(hosScheduleId);return this.packageSchedule(schedule);} 

1.3 最后在 rabbitMq管理web界面,清空队列    
Web管理界面
虚拟机IP:15672/#
账号密码都是 guest

2. 修改OrderServiceImpl类中public Long saveOrder(String scheduleId, Long patientId) 生成挂号订单 

//发送mq消息,号源更新和短信通知
//发送mq信息更新号源 错误的代码
OrderMqVo orderMqVo = new OrderMqVo();
orderMqVo.setScheduleId(scheduleId);  错误的
orderMqVo.setReservedNumber(reservedNumber);
orderMqVo.setAvailableNumber(availableNumber);

//正确的代码

OrderMqVo orderMqVo = new OrderMqVo();
orderMqVo.HosScheduleId());
orderMqVo.setReservedNumber(reservedNumber);
orderMqVo.setAvailableNumber(availableNumber);

错误原因:orderMqVo.setScheduleId(scheduleId); 保存的是传入的645ddd513d3a8a69f73a6a85
而我们 HospitalReceiver 中的receiver方法参数OrderMqVo的scheduleId 就是保存订单时候传入的scheduleId。而我们需要的hosScheduleId

修改之前:

 修改后:

本文发布于:2024-01-30 22:18:19,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170662429823223.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

上一篇:Mutual Mean
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23