Mongodb的可重试读操作

目录

重试读操作

需要条件

启用重读

支持可重试读的操作

不支持可重试读的操作

行为


重试读操作

连接mongodb进行读操作时,遇到网络或数据库集群的主节点切换导致的数据读问题。mongodb驱动自动尝试重新执行读操作。

需要条件

  • 数据库连接驱动支持mongodb4.2或以上版本。
  • 数据库服务器,需要3.6或以上版本。

启用重读

mongodb4.2或以上版本的驱动,默认允许可重试读。显示关闭可重试读。在数据库连接中设置retryReads=false。mongsh不支持可从试读操作。

支持可重试读的操作

复制代码
collection.aggregate
collection.count
collection.countDocument
collection.distinct
collection.estimatedDocumentCount
collection.find
database.aggregate
mongoClient.watch
mongoClient.listDatabases
database.listCollections
collection.listIndexes
某些数据库驱动还封装了一些重试读辅助方法或允许可重试读的方法。

不支持可重试读的操作

复制代码
db.collection.mapReduce()
getMore()
在database.runCommand中的读操作

行为

可重试读只能重试一次。能够帮忙检测网络问题或者复制集合主节点重新选择。无法支持长时间网络连接断开后的重试读操作。

在可重试读前,服务器选择读取节点按照原来命令指定的优先读取节点设置方式。如果数据库连接驱动无法选择一个使用原来的方式读取节点时,连接驱动会报错。在进行服务器选择时,驱动等待时间serverSelectionTimeoutMS。超过该设置时间后,可重试读不再连接数据库。

相关推荐
小诸葛的博客1 小时前
Go 语言中的select是做什么的
数据库·sql·golang
独泪了无痕2 小时前
数据库开发必备:理解DDL、DML、DQL和DCL
数据库·后端
Gauss松鼠会2 小时前
GaussDB Plan Hint调优实战:从执行计划控制到性能优化
数据库·sql·性能优化·database·gaussdb
zeijiershuai3 小时前
MySQL-SQL-DQL语句、DQL基本查询、DQL条件查询、DQL分组查询、聚合函数、DQL排序查询、DQL分页查询
数据库·sql·mysql
橙子家4 小时前
Redis 集群实现分布式缓存的示例操作流程【Redis 系列之五】
数据库
Jodie_Rao4 小时前
在 M1 芯片的 Mac 电脑上安装 Redis 可以通过 Homebrew 快速完成
数据库·redis·macos
weixin_409411024 小时前
面向数据库场景的大模型交互微调数据集
数据库·oracle·交互
东宇科技4 小时前
mysql中my.cnf权限不能过大。否则无法生效
数据库·mysql
Determined_man6 小时前
Mybatis-plus queryWrapper的使用
数据结构·数据库
飞奔的屎壳郎6 小时前
flink部署使用(flink-connector-jdbc)连接达梦数据库并写入读取数据
大数据·数据库·flink