`
风雪涟漪
  • 浏览: 496923 次
  • 性别: Icon_minigender_1
  • 来自: 大连->北京
博客专栏
952ab666-b589-3ca9-8be6-3772bb8d36d4
搜索引擎基础(Search...
浏览量:8767
Ae468720-c1b2-3218-bad0-65e2f3d5477e
SEO策略
浏览量:17675
社区版块
存档分类
最新评论

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

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

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics