fsync Command
fsync命令允许我们刷新所有等待写入的操作刷新到数据文件中。 更重要的是,它提供了锁的选项,这样会使备份更为简单。 fsync 命令强行将数据库刷新到数据文件中: > use admin > db.runCommand({fsync:1}); 这个命令执行完默认返回信息,为了及时返回可以使用如下命令: > db.runCommand({fsync:1,async:true});
定期执行的参数是在mongod启动时候设置的,参数为 --syncdelay . 默认的刷新时间为60s。
锁,快照和解锁。(Lock, Snapshot and Unlock)
fsync命令支持锁的选项,这样就可以安全的快照数据库的数据文件。 当锁住了,虽然所有的读操作仍然好用,但是所有的写操作被阻塞了。 当快照之后,使用unlock命令去解锁并且可以再次上锁。 > use admin switched to db admin > db.runCommand({fsync:1,lock:1}) {"info" : "now locked against writes","ok" : 1} > db.currentOp(){"inprog" : [],"fsyncLock" : 1} >// do some work here: for example, snapshot datafiles...
>// runProgram("/path/to/my-filesystem-snapshotting-script.sh")
> db.$cmd.sys.unlock.findOne(); { "ok" : 1, "info" : "unlock requested" } > // 请求解锁,需要一点时间执行。
> db.currentOp(){ "inprog" : [ ] }
警告当加锁的时候,database还是可以读取的,如果有写入操作, 就会阻塞读的操作。 http://jira.mongodb.org/browse/SERVER-1423 快照从服务器pshotting Slaves上述的过程工作在从服务器的话. 当上锁的时候,任何操作也就不生效了。 |