当与数据库网络出现连接问题或在数据库集群主节点切换时不能找到一个正在工作的主节点时,可重试写允许数据库连接驱动再进行一次数据库写入操作。
mongosh --retryWrites=false
db.collection.insertOne()
db.collection.insertMany()
db.collection.updateOne()
db.collection.replaceOne()
db.collection.deleteOne()
db.collection.remove(),需要设置选项(justOne:true)
db.collection.findAndModify()
db.collection.findOneAndDelete()
db.collection.findOneAndReplace()
db.collection.findOneAndUpdate()
db.collection.bulkWrite()中的单文档写入操作
insertOne
updateOne
replaceOne
deleteOne
bulkOperation的单文档删除操作
removeOne()
replaceOne()
mongodb仅支持重试一次写入操作。用来帮助定位网络问题或数据库主节点重新选择。长时间网络连接问题时,无法重写。数据库驱动在用户设置或系统默认的serverSelectionTimeoutMS内进行重写,超过这个时间不会重试写入。
db.serverStatus()
db.runCommand({"serverStatus": 1})
mongodb自4.2版本开始默认支持可重试写入。数据库升级到4.2版本时,向local数据库写入数据会报错,除非显示指定不支持可重试写入。
自mongodb 6.1版本开始,如果对单文档操作的两次写入都失败,mongodb会返回一个带有NoWritesPerformed标签的错误。该标签用来区分批量操作的结果。如insertMany()操作
应用可以使用这个标签来判断是否有文档插入。这个错误是用户获得一个准确的数据插入信息。而在以前版本中,两次写入后直接返回一个错误,无法确定是否有数据插入。