MongoDB 同步命令 fsync Command
fsync命令允许我们刷新所有等待写入的操作刷新到数据文件中。
更重要的是,它提供了锁的选项,这样会使备份更为简单。
?fsync 命令强行将数据库刷新到数据文件中:
> use admin
> db.runCommand({fsync:1});这个命令执行完默认返回信息,为了及时返回可以使用如下命令:
> db.runCommand({fsync:1,async:true});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
上述的过程工作在从服务器的话. 当上锁的时候,任何操作也就不生效了。