MongoDB 同步命令 fsync Command

fsync Command

注意,只支持1.3+版本

fsync命令允许我们刷新所有等待写入的操作刷新到数据文件中。

更重要的是,它提供了锁的选项,这样会使备份更为简单。

 fsync 命令强行将数据库刷新到数据文件中:

> use admin
> db.runCommand({fsync:1});

这个命令执行完默认返回信息,为了及时返回可以使用如下命令:

> db.runCommand({fsync:1,async:true});


定期执行的参数是在mongod启动时候设置的,参数为 --syncdelay .  默认的刷新时间为60s。

锁,快照和解锁。(Lock, Snapshot and Unlock)

 journaling 开启, 你就不需要为了快照而上锁了。 请查看 backups 页面.

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

上述的过程工作在从服务器的话. 当上锁的时候,任何操作也就不生效了。

你可能感兴趣的:(mongodb,工作)