MongoDB更新失败怎么办,如何才能减少失败
Admin 2022-05-27 群英技术资讯 1354 次浏览
这篇文章主要讲解了“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);
}
}
});
如此失败率,大大减少。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章给大家分享的是MongoDB怎样进行安装的内容。下文的安装操作对新手安装MongoDB有一定的帮助,因此分享给大家做个参考,文中教程非常详细,感兴趣的朋友接下来一起跟随小编看看吧。
你知道Mongodb怎样自增id吗?对于这个问题相信很多初学的小伙伴都是不了解的,那么今天小编就利用实例为大家讲述Mongodb自增id实现方法,希望对大家有所帮助。
mongodb设置账号密码可以通过重启mongodb数据库生效。我们可以使用“Crtl+C”快捷键或使用“db.shutdownServer()”命令关闭数据库。
Node.js 连接 MongoDB MongoDB是一种文档导向数据库管理系统,由C++撰写而成。 本章节我们将为大家介绍如何使用 Node.js 来连接 MongoDB,并对数据库进行操作。 如果你还没有 MongoDB 的基本知识,可以参考我们的教程:MongoDB 教程。 安装驱动 本教程使用了淘宝定制的 cnpm 命令进行安装: $ cnpm install mongodb 接下来我们来实现增删改查功能。 创建数据库 ..
MongoDB数据库remove()方法的作用:1、删除整个集合中的所有数据;2、删除集合中符合过滤条件的数据;3、删除符合条件的一条记录。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008