MongoDB更新失败怎么办,如何才能减少失败
这篇文章主要讲解了“MongoDB更新失败怎么办,如何才能减少失败”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“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更新失败怎么办,如何才能减少失败”的文章就介绍到这了,更多相关的内容,欢迎关注博信,小编将为大家输出更多高质量的实用文章!
版权声明
本文仅代表作者观点,不代表博信信息网立场。