admin管理员组文章数量:1794759
Thread.sleep 延时查询或延时查询前更新es缓存数据
Thread.sleep 延时查询或延时查询前更新es缓存数据
MQ消息的顺序性,或发送MQ的发送端未严格事务处理,可能存在数据未落库的情况,而导致接收端处理MQ消息的时候,查询为空。
代码语言:javascript代码运行次数:0运行复制//demo1 订单
Order Order = OrderMapper.getOrder(orderNo);
if (Order == null) {
//延时3秒
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
log.error("查询Order延时3秒异常:orderNo=[{}]",e,orderNo);
}
Order = OrderMapper.getOrder(orderNo);
if (Order == null) {
throw new RuntimeException("Order is null , orderNo = " + orderNo);
}
}
//demo2 查询es
Order bo = orderSearchService.detail(orderNo);
if(bo == null){
//es尝试刷新一次
List<String> orderNoList = Arrays.asList(orderNo);
orderSearchService.refresh(orderNoList);
Thread.sleep(3000);
//重新查询
bo = orderSearchService.detail(orderNo);
if(bo == null){
logger.info("es查询订单信息Order is null , orderNo = " + orderNo);
return content;
}
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。 原始发表:2023-03-15,如有侵权请联系 cloudcommunity@tencent 删除thread数据异常essleep本文标签: Threadsleep 延时查询或延时查询前更新es缓存数据
版权声明:本文标题:Thread.sleep 延时查询或延时查询前更新es缓存数据 内容由林淑君副主任自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.xiehuijuan.com/baike/1754979711a1708977.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论