zoukankan      html  css  js  c++  java
  • MongoDBOplog详解

    https://www.cnblogs.com/operationhome/p/10688798.html

    Oplog 是用于存储 MongoDB 数据库所有数据的操作记录的(实际只记录增删改和一些系统命令操作,查是不会记录的),有点类似于 mysql 的 binlog 日志。

    Oplog 的存在极大地方便了 MongoDB 副本集的各节点的数据同步,MongoDB 的主节点接收请求操作,然后在 Oplog 中记录操作,次节点异步地复制并应用这些操作。

    Oplog 存储在 local 库的 oplog.rs 集合里面。对于一般的线上环境来说,默认的 Oplog 值就已经足够了。当达到储存大小的日志时,新的记录会将老的记录覆盖。

    但是我们系统中如果存在以下操作的话,那么我们就可能需要设置更大的 Oplog 值来避免数据的丢失(在副本集中数据同步过程):

    Oplog 常用命令:

    查看 Oplog 的状态:rs.printReplicationInfo()

    fymongodb:PRIMARY> rs.printReplicationInfo()
    configured oplog size:   15000MB
    log length start to end: 7437secs (2.07hrs)
    oplog first event time:  Thu Apr 11 2019 09:40:31 GMT+0800 (CST)
    oplog last event time:   Thu Apr 11 2019 11:44:28 GMT+0800 (CST)
    now:                     Thu Apr 11 2019 11:44:35 GMT+0800 (CST)

    如何查看当前的 Oplog 存储设置的大小:db.oplog.rs.stats().maxSize

    fymongodb:PRIMARY> use local
    fymongodb:PRIMARY> db.oplog.rs.stats().maxSize
    NumberLong("15728640000")
    查看 Oplog 最大大小和现在占用的大小,以及记录时长和时间 :db.getReplicationInfo()
    fymongodb:PRIMARY> db.getReplicationInfo()
    更改副本集成员的 Oplog 大小,更改的值要大于等于990MB,这里设置为1500MB : db.adminCommand({replSetResizeOplog: 1, size: 15000})
    fymongodb:PRIMARY> db.adminCommand({replSetResizeOplog: 1, size: 15000})
    Oplog 的值是储存在 local 库下的 集合 oplog.rs 里的。我们可以分析其中的一条日志,看到到底记录了写什么。
    # 获取日志 use local db.polog.rs.find()
    Oplog 的日志由 key value 组成。 ts 的值: 表示该日志的时间戳 op 的值: i 表示 insert ,u 表示 update, d 表示 delete,
    c 表示的是 db cmd, db 表示声明当前数据库 (其中ns 被设置成为=>数据库名称+ '.'),
    n 表示 noop,,即空操作,其会定期执行以确保时效性
    ns 的值: 表示操作所在的数据库和集合。
    ui 的值: 表示当前登录用户的会话 id 值。
    wall 的值: 表示该操作的执行时间,
    utc时间。
    o 的值: 表示操作的内容,如果是插入,就会将插入的数据放到该位置。示例日志就是插入了一条数据{"name":"youju"}
     
  • 相关阅读:
    FFT 优化和任意模数 FFT
    构造 DFT :某少女附中的体育课 题解
    多项式操作
    String主要方法
    我的第一篇java笔记
    个人作业——软件评测
    软件工程实践2019第五次作业
    软件工程实践2019第四次作业
    软件工程实践2019第三次作业
    软件工程实践2019第二次作业
  • 原文地址:https://www.cnblogs.com/vzhangxk/p/14458138.html
Copyright © 2011-2022 走看看