设为首页 收藏本站
查看: 1044|回复: 0

[经验分享] MongoDB的几种同步方式

[复制链接]

尚未签到

发表于 2017-12-15 07:16:27 | 显示全部楼层 |阅读模式
  在对MongoDB使用的过程中,总结了几种常用的备份、恢复、同步的方式。
  1、冷拷贝
  这种方式对数据同步的完整性保持的最好,同时也非常方便,但是会影响服务器的使用。
  首先关闭源数据库服务,之后使用远程复制命令将数据文件全量拷贝到目标服务器的数据目录下,再启动目标服务器。
  如果不关闭源数据库,将会导致部分数据没有写到数据文件中,有很大概率目标服务器无法启动。
  2、使用mongodump
  mongodump是mongodb官方提供的导出工具,使用起来非常简单,一个例子如下
  mongodump --host example.net --port 37017 -o /opt/backup/mongodump -d dbname -c collectionname
  通过host port参数指定主机,通过o参数指定输出目录,通过d参数指定数据库,通过c参数指定集合
  mongodump会自动建立备份目录,并按照数据库,集合划分目录与文件。
  对应的,官方还提供了mongorestore程序来恢复备份,命令类似于mongodump。使用相同的参数指定主机,数据库,集合等信息,最后一个参数默认为用来恢复的数据文件目录即可。
  还有几个需要注意的问题:
  mognodb不会导出索引数据,所以在恢复后需要重新建立索引。
  备份过程中所做的修改可能无法写入到备份文件中,如果需要同步这一些数据,可以使用--oplog参数记录过程中的修改日志,同时需要服务器为副本集或主从模式,否则数据库不会产生oplog。
  3、增量备份
  当数据库为副本集的主节点或主从模式的主节点时,将会生成操作日志,mongodb会使用操作日志对各节点中的数据进行增量同步。
  利用这一点,我们也可以对集群之外的节点做同样的增量同步。
  oplog数据存储在数据库的local数据库下。
  主要字段如下
名称说明ts操作的时间戳,8字节,mongodb自身的时间戳格式op操作类型,包括:i插入,u更新,d删除,c数据库命令,n无操作ns数据库与集合名称h  操作的唯一id
o  操作的内容
o2  更新时的条件
  有了这些信息,我们就可以用代码模拟mongodb的同步模式,对操作日志实现重播,从而实现数据的增量同步。
  基本代码逻辑如下:
  ns = oplog['ns']
  index = ns.find('.')
  dbname = ns[0:index]
  collname = ns[index + 1:]
  op = oplog['op']
  if op == 'i':  # insert
  dest_mc[dbname][collname].save(oplog['o'])  # if exist,recover it
  elif op == 'u':  # update
  dest_mc[dbname][collname].update(oplog['o2'], oplog['o'])
  elif op == 'd':  # delete
  dest_mc[dbname][collname].remove(oplog['o'])
  elif op == 'n':  # no-op
  logging.info('no-op')
  else:
  logging.error('unknown command: %s' % (oplog))

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-424240-1-1.html 上篇帖子: MongoDB-创建/删除数据库 下篇帖子: mongoDB数据库
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表