文档章节

MongoDB主从集群部署 - 建议方法三(方便运维)

C-Kellen
 C-Kellen
发布于 2017/07/26 17:05
字数 1476
阅读 23
收藏 0

一、 主从部署模型图

二、 主数据的好处

  1.  数据备份 只能从master节点复制内容不能从slave节点复制因为slave节点不保存oplog操作日记
  2.  数据恢复
  3.  读写分离

三、 介绍

MongoDB的master-salva复制其实很简单

在运行主master的服务器上开启mongod进程时,加入参数--master即可。

cd mongodb/bin/
mongod -dbpath ~/dbs/master -port 27037 -master

在运行从slave的服务器上开启mongod进程时,加入参数--slave 和 --source 指定主即可。

cd mongodb/bin/
mongod -dbpath ~/dbs/slave -port 27037 -slave -source 192.168.0.188:27037

这样,在master数据库更新时,数据被复制到slave数据库中。

一、 构建方法介绍

    构建方法有两种:

        一是:分别在两台机子上声明master-slave从身份;

        二是:先声明slave服务器,后期再添加master服务器

二、 方法一

  1.  构造一个master和一个slave

    x1    192.168.0.188        master
    x2    192.168.0.189        slave
  2.  创建存放数据文件

    x1 上运行
    mkdir -p ~/dbs/master

     

    x2 上运行
    mkdir -p ~/dbs/slave
      
  3.  部署

    1.  部署master

      cd mongodb/bin/
      mongod -dbpath ~/dbs/master -port 27037 -master
    2.  部署slave

      cd mongodb/bin/
      mongod -dbpath ~/dbs/slave -port 27037 -slave -source 192.168.0.188:27037

       

  4.  验证

    1.  master服务器里插入数据

      1.  进入js编辑环境进行数据插入:

        cd mongod/bin/
        
        ./mongod
        
        db.a.save({line:"hello word"})
    2.  slave服务器是否能同步

      1.  进入js编辑环境进行数据查询:

        cd mongod/bin/
        
        ./mongod
        
        db.a.find({})
  5.  成功结束

三、 方法二

  1.  构造一个master和一个slave

    x1    192.168.0.188        master
    x3    192.168.0.190        slave

     

  2.  创建存放数据文件

    x1 上运行
    mkdir /dbs/master

    x3 上运行
    mkdir /dbs/slave
  3.  部署

    1.  部署master

      cd mongodb/bin/
      ./mongod --master --dbpath /data/master --port 27017
    2.  部署slave

      cd mongodb/bin/
      
      ./mongod --slave --dbpath /data/slave --port 27017
  4.  slave插入数据源

    cd mongod/bin/
    
    ./mongod
    
    use local 
    
    db.sources.insert({“host”:"192.168.0.188:27017"})
    
    #PS:移除数据源 db.sources.remove({“host”:"192.168.0.188:27017"})
  5.  验证

    1.  master服务器里插入数据

      1.  进入js编辑环境进行数据插入:

        cd mongod/bin/
        
        ./mongod
        
        db.a.save({line:"happy new year"})

    2.  slave服务器是否能同步

      1.  进入js编辑环境进行数据查询:

        cd mongod/bin/
        
        ./mongod
        
        db.a.find({})

  6. 成功结束

四、 方法三(配置文件):

  1.  构造一个master和一个slave

    x1    192.168.0.188        master
    x2    192.168.0.189        slave
  2.  创建存放数据文件

    x1 上运行
    mkdir /mongodb/data/db/master
    mkdir /mongodb/log

    x2 上运行
    mkdir /mongodb/data/db/slave
    mkdir /mongodb/log

  3. 创建编辑配置文件

    #主配置/mongodb/conf/master.conf
    
    port = 27017
    dbpath = /mongodb/data/db/master
    logpath = /mongodb/log/master.log
    logappend = true
    journal = true
    fork = true
    master = true
    rest=true
    nohttpinterface=false
    
    
    #从配置#/mongodb/conf/slave.conf
    
    port = 27017
    dbpath = /mongodb/data/db/slave
    logpath = /mongodb/log/slave.log
    logappend = true
    journal = true
    fork = true
    slave = true  # 指定该mongodb为slave模式
    source = 192.168.0.188:27017  # 指定master服务器
    rest=true
    nohttpinterface=false
    slavedelay=10               #延迟复制,单位为秒
    autoresync=true             #当发现从服务器的数据不是最新时,向主服务器请求同步数据

     

  4. 启动主从

    #先启动主
    cd mongodb/bin/
    mongod -f /mongodb/conf/master.conf 
    
    #启动从
    cd mongodb/bin/
    mongod -f /mongodb/conf/slave.conf 

     

  5. 验证同上

四、 启动服务器的参数说明:

--dbpath		数据库路径(数据文件)
--logpath		日志文件路径
--master 		指定为主机器
--slave 		指定为从机器
--source 		指定主机器的IP地址
--pologSize 	命令行参数(与--master一同使用)配置用于存储给从节点可用的更新信息占用的磁盘空间(M为单位),如果不指定这个参数,默认大小为当前可用磁盘空间的5%(64位机器最小值为1G,32位机器为50M)。
--logappend 	日志文件末尾添加
--port 			启用端口号
--fork 			在后台运行
--only 			指定只复制哪一个数据库
--slavedelay 	指从复制检测的时间间隔
--auth 			是否需要验证权限登录(用户名和密码)

-h [ --help ]             show this usage information
--version                 show version information
-f [ --config ] arg       configuration file specifying additional options
--port arg                specify port number
--bind_ip arg             local ip address to bind listener - all local ips
                           bound by default
-v [ --verbose ]          be more verbose (include multiple times for more
                           verbosity e.g. -vvvvv)
--dbpath arg (=/data/db/) directory for datafiles    指定数据存放目录
--quiet                   quieter output   静默模式
--logpath arg             file to send all output to instead of stdout   指定日志存放目录
--logappend               appnd to logpath instead of over-writing 指定日志是以追加还是以覆盖的方式写入日志文件
--fork                    fork server process   以创建子进程的方式运行
--cpu                     periodically show cpu and iowait utilization 周期性的显示cpu和io的使用情况
--noauth                  run without security 无认证模式运行
--auth                    run with security 认证模式运行
--objcheck                inspect client data for validity on receipt 检查客户端输入数据的有效性检查
--quota                   enable db quota management   开始数据库配额的管理
--quotaFiles arg          number of files allower per db, requires --quota 规定每个数据库允许的文件数
--appsrvpath arg          root directory for the babble app server 
--nocursors               diagnostic/debugging option 调试诊断选项
--nohints                 ignore query hints 忽略查询命中率
--nohttpinterface         disable http interface 关闭http接口,默认是28017
--noscripting             disable scripting engine 关闭脚本引擎
--noprealloc              disable data file preallocation 关闭数据库文件大小预分配
--smallfiles              use a smaller default file size 使用较小的默认文件大小
--nssize arg (=16)        .ns file size (in MB) for new databases 新数据库ns文件的默认大小
--diaglog arg             0=off 1=W 2=R 3=both 7=W+some reads 提供的方式,是只读,只写,还是读写都行,还是主要写+部分的读模式
--sysinfo                 print some diagnostic system information 打印系统诊断信息
--upgrade                 upgrade db if needed 如果需要就更新数据库
--repair                  run repair on all dbs 修复所有的数据库
--notablescan             do not allow table scans 不运行表扫描
--syncdelay arg (=60)     seconds between disk syncs (0 for never) 系统同步刷新磁盘的时间,默认是60s

 

 

© 著作权归作者所有

共有 人打赏支持
C-Kellen
粉丝 20
博文 106
码字总数 80242
作品 0
朝阳
程序员
MongoDB 最佳实践及2.8版本特性与功能

主要流程 MongoDB 2.8 版本特性与功能 MongoDB 在赶集网的应用 MongoDB 最佳实践 MongoDB 2.8 版本特性与功能 TJ MongoDB 开发者 TJ 强调 MongoDB 没有实际意义上的锁,只有 Latch,门栓。 ...

eui988
2015/04/18
0
1
阿里专家视频课限时抢!精讲+实操12节课学懂MongoDB数据库!

想要学习MongoDB却不知道如何入门? 漫天的培训课程却无一讲解实战案例? 云栖社区联手阿里云大学独家出品—— 阿里云MongoDB技术负责人、MongoDB中文社区联席主席联合操刀 12期精讲+实操,全...

a独家记忆
07/12
0
0
阿里云正式开源MongoDB容灾和多活解决方案平台--MongoShake

6月27日,阿里云宣布正式开源基于MongoDB的容灾和多活解决方案平台--MongoShake(github地址),该系统可以跨数据中心进行数据同步,最高处理QPS可达50万左右,使得跨数据中心的高效的灾备和...

Mr_zebra
06/29
0
0
活动丨新型数据库是怎样解决个性化需求的?

随着数据量不断膨胀,以及企业对数据挖掘、分析、应用需求的持续增长,传统的数据库技术已逐渐难以满足日益多样化的需求,因此,不少新型数据库应运而生。这些新型数据库往往针对某个行业或是...

09/13
0
0
没有宫廷内斗,数据库界的延禧攻略

各位老铁们,你们有没有想老张,最近老张的才华被工作的繁忙所限制了,所以一直没时间更博,今儿个时隔数日我们终于再次见面啦(很开心)!最近有部特别火的宫廷戏,不知道大家有没有看,剧名...

superZS
08/27
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Spring Boot 入门 - 进阶篇(4)- REST访问(RestTemplate)

经常需要发送一个GET/POST请求到其他系统(REST API),通过JDK自带的HttpURLConnection、Apache HttpClient、Netty 4、OkHTTP 2/3都可以实现。 HttpClient的使用:http://rensanning.iteye.c...

onedotdot
6分钟前
0
0
Wi-Fi也有版本号了!

据Solidot消息,行业组织 Wi-Fi 联盟宣布当前的版本 Wi-Fi 802.11ac 重命名为 Wi-Fi 5,而下一个版本 802.11ax 重命名为 Wi-Fi 6,之前的版本 802.11n 改名为 Wi-Fi 4。 Wi-Fi 标准之前使用单...

linux-tao
7分钟前
0
0
项目经验不丰富、技术不突出的程序员怎么打动面试官?

前言 相信不少的程序员都有过类似的困惑:如果我没有大型的项目经历,也不能靠技术征服面试官,那我要怎么才能给面试官留下一个好印象呢? 按照本人的面试经验来说,面试主要看几点:项目经验...

Mamba1
18分钟前
1
0
MyBatis 源码分析----MyBatis 整体架构概要说明

MyBatis整体架构 MyBatis的整体架构分为三层1:基础支持层,2:核心处理层,3:接口层 1:基础支持层: 1-1反射模块: 该模块对Java 原生的反射进行了良好的封装,提供了更加简洁易用的API ,...

西瓜1994
23分钟前
4
0
如何让 J2Cache 在多种编程语言环境中使用

现在的系统是越来越复杂了,不仅仅是功能复杂,系统结构也非常复杂,而且经常在一个系统里包含几种不同语言编写的子系统。例如用 JavaScript 做前端开发、用 Java/PHP 等等做后端,C/C++/Go ...

红薯
25分钟前
35
1

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部