学堂 学堂 学堂公众号手机端

MongoDB更新失败怎么办,如何才能减少失败

lewis 1年前 (2024-03-21) 阅读数 5 #技术
这篇文章主要讲解了“MongoDB更新失败怎么办,如何才能减少失败”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MongoDB更新失败怎么办,如何才能减少失败”吧!


现象:

WriteResultres=mongoTemplate.updateFirst(query,updateObj,"ServerToAgentReq_SMS");

获取res.getN()返回值时,发现偶尔情况下该返回值为0,表示该更新操作没有更新到任何数据。并且如果是多线程并发更新,失败几率大大提高。

官网表示不能保证更新操作的成功性....

方案:

一次失败后,另起线程多次重试。

privateThreadPoolExecutorexec=newThreadPoolExecutor(2,10,3,TimeUnit.SECONDS,newArrayBlockingQueue<Runnable>(10),newThreadPoolExecutor.CallerRunsPolicy());
主要代码:
WriteResultres=mongoTemplate.updateFirst(query,updateObj,"ServerToAgentReq_SMS");
//如果更新失败,进入其他线程重试更新
if(res.getN()==0){
exec.execute(newRunnable(){
@Override
publicvoidrun(){
intnum=0;
WriteResultres=mongoTemplate.updateFirst(query,updateObj,"ServerToAgentReq_SMS");
while(res.getN()==0&&num<100){
res=mongoTemplate.updateFirst(query,updateObj,"ServerToAgentReq_SMS");
num++;
try{
Thread.sleep(300);
}catch(InterruptedExceptione){
logger.error("响应更新失败{}",e);
}
}
if(res.getN()==0){
logger.error("响应更新失败!!!gwMsgId:{},masMsgId:{}",gwMsgId,masMsgId);
}
}
});

如此失败率,大大减少。


这篇关于“MongoDB更新失败怎么办,如何才能减少失败”的文章就介绍到这了,更多相关的内容,欢迎关注博信,小编将为大家输出更多高质量的实用文章!
版权声明

本文仅代表作者观点,不代表博信信息网立场。

热门