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

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

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值