时间:2021-07-01 10:21:17 帮助过:18人阅读
writeConcern决定一个写操作落到多少个节点上才算成功,这决定了mongodb是否会丢失数据。
writeConcern的取值包括:
发起写操作的程序将阻塞到写操作到达指定的节点数为止。
应用程序试图写入x=1,进入mongodb的primary节点,一旦写入primary(未必是写到磁盘里,可能只是写入到内存中),就向客户端响应acknowledge。
之后由mongodb另外的线程将数据由primary异步复制到secondary1和secondary2。此时如果primary发生crash,会导致该数据丢失。
要解决上述问题,可以使用大多数节点确认模式。
当x=1写入primary后没有返回,写入进程等待数据复制到secondary1或者secondary2后primary发送acknowledge。
此时如果primary发生crash,secondary1会成为新的主节点。
数据要写入全部节点,才返回成功。
j:true
日志的作用是给一个数据库节点在宕机的时候可以快速恢复刚才的写操作,所以一般数据库都先写日志文件,再写数据文件。
默认一个操作进到primary内存的时候,并不会等写日志,而就返回了。
writeConcern可以决定写操作到达多少个节点才算成功,journal则定义如何才算成功。取值包括:
对于5个节点的复制集来说,写操作落到多少个节点上才算是安全的?
在复制集测试writeConcern参数
db.test.insert({count:1},{writeConcern:{w:"majority"}})
db.test.insert({count:1},{writeConcern:{w:3}})
db.test.insert({count:1},{writeConcern:{w:4}})
配置延迟节点,模拟网络延迟(复制延迟)
conf=rs.conf()
conf.members[2].slaveDelay=5 // 等待5s去同步主节点数据
conf.memvers[2].priority=0 // 如果有延迟,则不可以参与选举
rs.reconfig(conf)
观察复制延迟下的写入,以及timeout参数
db.test.insert({count:1},{writeConcern:{w:3}})
db.test.insert({count:1},{writeConcern:{w:3,wtimeout:3000}}) // 数据可能已经写入,需要根据日志等进行后续操作
MongoDB事务开发:写操作事务
标签:复制集 count 观察 conda 网络 计算 als 节点 阻塞