这篇文章主要讲解了“MongoDB更新失败怎么办,如何才能减少失败”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MongoDB更新失败怎么办,如何才能减少失败”吧!
现象:
WriteResult res = mongoTemplate.updateFirst(query, updateObj, "ServerToAgentReq_SMS");
获取res.getN()返回值时,发现偶尔情况下该返回值为0,表示该更新操作没有更新到任何数据。并且如果是多线程并发更新,失败几率大大提高。
方案:
一次失败后,另起线程多次重试。
private ThreadPoolExecutor exec = new ThreadPoolExecutor(2, 10, 3, TimeUnit.SECONDS, new ArrayBlockingQueue<Runnable>(10), new ThreadPoolExecutor.CallerRunsPolicy());
主要代码:
WriteResult res = mongoTemplate.updateFirst(query, updateObj, "ServerToAgentReq_SMS");
//如果更新失败,进入其他线程重试更新
if (res.getN() == 0) {
exec.execute(new Runnable() {
@Override
public void run() {
int num = 0;
WriteResult res = 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 (InterruptedException e) {
logger.error("响应更新失败{}", e);
}
}
if (res.getN() == 0) {
logger.error("响应更新失败!!!gwMsgId:{},masMsgId:{}", gwMsgId, masMsgId);
}
}
});
如此失败率,大大减少。
这篇关于“MongoDB更新失败怎么办,如何才能减少失败”的文章就介绍到这了,更多相关的内容,欢迎关注,小编将为大家输出更多高质量的实用文章!