• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >MongoDB > MongoDB的Master-Slave主从模式配置及主从复制要点解析

MongoDB的Master-Slave主从模式配置及主从复制要点解析

作者:Hunk Shi 字体:[增加 减小] 来源:互联网 时间:2017-05-11

Hunk Shi通过本文主要向大家介绍了mongodb主从复制,mongodb主从,mongodb 主从配置,mongodb应用设计模式,蓝牙主从模式等相关知识,希望本文的分享对您有所帮助

主从配置
mongodb的master-slave模式配置方式如下
1.keyFile
生成key_file

 openssl rand -base64 741 > mongo_key
</div>

将mongo_key 分别置于master 和 slave mongodb user可以access的地方。
设置权限

chmod 700 mongo_key
</div>

设置

onwer chown mongodb:nogroup mongo_key
</div>

2.master配置
编辑/etc/mongodb.conf, 设置如下

master = true
keyFile = /path/to/mongo_key
</div>

3.slave 配置

slave = true
source = <ip of master>
only = bookstore
keyFile = /usr/local/bookstore/mongo_key
</div>

如果只同步一个db,配置only项,如果多个DB需同步,注释掉only项。
以上设置完毕后即可启动master和slave了,如果配置有误会启动失败,比如key_file权限不正确,具体错误可以查看/var/log/mongodb/mongodb.log。如无误,即可在master上修改一些记录进行验证了。
4.配置更改
master-slave配置比较简单,但要修改已经运行正确的配置缺不是想象的那么简单。例如要更改master地址,或者去除only配置。因为mongodb启动时,会将配置写入DB中,master的配置在local DB的slaves表中, slave的配置在local DB的sources表中。如果单独更改conf文件,直接重启会失败,log中显示和DB中的配置冲突。如果直接修改local DB,修改会很快被覆盖。
5.操作办法
取消slave配置重启。即注释掉slave = true这一行。
手动修改sources表,例如更改master 的ip或者去除only 项。
修改conf文件,打开slave = true,并修改其他项,例如更改master 的ip或者去除only 项。
再次重启mongodb。
6.其他问题
手动强制同步:
如果slave因为特殊原因和master不同步,需要手动强制同步,方法为在slave上运行如下命令:

use admin
db.runCommand( { resync: 1 } )
</div>

如果数据落后较多,则需要较长时间。

主从同步要点解析
主服务器和从服务器必须开启安全认证:--auth, 主服务器和从服务器的admin数据库中必须有全局用户, 然后主服务器的local数据库和从服务器的local数据均有名为repl且密码相同的用户名。
注:local:本地数据库 这个数据库不会同步,主要存放同步的信息。在MongoDB2.0.2版本测试时,从服务器的admin数据库中没有全局用户时也能进行复制(Deven:我们就是采用这个方式,
从服务器admin数据库没有建立用户),尽管admin中无用户,客户端连接此服务器不进行验证(即--auth参数失效),但从服务器的--auth必须指定。既然启用了--auth,就应该在从服务器的admin中增加一个用户。

首先要在master的local数据库中创建名为repl的账户,并设置密码;
从服务器上和master一样 创建名为repl的账户,并设置和master上一样的密码;
然后创建一个全局账户(管理账户,开启同步即可)
1.创建一个全局账户

> use admin
switched to db admin
> db.addUser("root","zhuima")
WARNING: The 'addUser' shell helper is DEPRECATED. Please use 'createUser' instead
Successfully added user: { "user" : "root", "roles" : [ "root" ] }

</div>

2.分别在master/slave的local数据库下创建一个名为repl的账户,并设置密码相同

> use local
switched to db local
> db.addUser("repl","zhuima")
WARNING: The 'addUser' shell helper is DEPRECATED. Please use 'createUser' instead
Successfully added user: { "user" : "repl", "roles" : [ "dbOwner" ] }

</div>

3.master配置文件

[root@redis ~]# sed -e '/^$/d;/^#/d' /etc/mongodb.conf 
bind_ip = 192.168.58.30
port = 27017
fork = true
pidfilepath = /var/run/mongodb/mongodb.pid
logpath = /var/log/mongodb/mongodb.log
dbpath =/mydata/data
journal = true
auth = true# 开启认证模式
master = true          # 指定该mongodb为master模式

</div>

4.slave配置文件

[root@localhost ~]$ sed -e '/^$/d;/^#/d' /etc/mongodb.conf 
bind_ip = 192.168.58.10
port = 27017
fork = true
pidfilepath = /var/run/mongodb/mongodb.pid
logpath = /var/log/mongodb/mongodb.log
dbpath = /mydata/data
journal = true
auth = true  # 开启认证模式
slave = true  # 指定该mongodb为slave模式
source = 192.168.58.30:27017  # 指定master服务器

</div>

5.检查同步情况

> db.printReplicationInfo()
this is a slave, printing slave replication info.
source:  192.168.58.30:27017
 syncedTo: Fri Jul 18 2014 10:22:31 GMT+0200 (CEST)
 = 22 secs ago (0.01hrs)  # 这个是指延迟时长
</div>

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • mongoDB 实现主从读写分离实现的实例代码
  • MongoDB 主从复制实例讲解
  • MongoDB的主从复制及副本集的replSet配置教程
  • MongoDB的Master-Slave主从模式配置及主从复制要点解析
  • MongoDB入门教程之主从复制配置详解
  • 详解mongodb 主从配置

相关文章

  • 2017-05-11MongoDB系列教程(一):NoSQL起源
  • 2017-05-11MongoDB插入、更新、删除文档实现代码
  • 2017-05-11MongoDB.NET 2.2.4驱动版本对Mongodb3.3数据库中GridFS增删改查
  • 2017-05-11MongoDB 学习笔记
  • 2017-05-11MongoDB查询性能优化验证及验证
  • 2017-05-11阿里云CentOS7安装Mongodb教程
  • 2017-05-11MongoDB教程之基本管理命令
  • 2017-05-11mongoDB在windows下安装与配置方案
  • 2017-05-11mongodb 命令行下及php中insert数据详解
  • 2017-05-11MongoDB中强大的统计框架Aggregation使用实例解析

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • mongodb replica set 添加删除节点的2种方法
    • Mongo管理用户相关操作总结
    • MongoDB安装为service报错100(windows系统)
    • Mongodb索引的优化
    • Ubuntu下安装mongodb 3.4的详细过程
    • mongodb 数据库操作--备份 还原 导出 导入
    • MongoDB错误32-bit servers don't have journaling enabled by default解决方法
    • mongodb错误tcmalloc: large alloc out of memory, printing stack and exiting解决办法
    • mongodb replica set 配置高性能多服务器详解
    • 给MongoDB添加用户权限方法分享

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有