MongoDB3.0.6搭建主从复制集

作者: tony_zhang | 来源:发表于2020-01-29 11:01 被阅读0次

    什么是复制集?

    • 复制集(Replica Sets)是额外的数据副本,是跨多个服务器同步数据的过程,复制集提供了冗余并增加了数据可用性,通过复制集可以对硬件故障和中断的服务进行恢复。
      或者
      MongoDB复制是将数据同步在多个服务器的过程。复制提供了数据的冗余备份,并在多个服务器上存储数据副本,提高了数据的可用性, 并可以保证数据的安全性。复制还允许您从硬件故障和服务中断中恢复数据。


    • mongodb(M)表示主节点,mongodb(S)表示备节点,mongodb(A)表示仲裁节点。主备节点存储数据(M,S),仲裁节点不存储数据。客户端同时连接主节点与备节点,不连接仲裁节点。
    • 默认设置下,主节点提供所有增删查改服务,备节点不提供任何服务。但是可以通过设置使备节点提供查询服务,这样就可以减少主节点的压力,当客户端进行数据查询时,请求自动转到备节点上。这个设置叫做Read Preference Modes,同时Java客户端提供了简单的配置方式,可以不必直接对数据库进行操作。
    • 仲裁节点是一种特殊的节点,它本身并不存储数据,主要的作用是决定哪一个备节点在主节点挂掉之后提升为主节点,所以客户端不需要连接此节点。这里虽然只有一个备节点,但是仍然需要一个仲裁节点来提升备节点级别。

    搭建复制集

    • 准备
      mongo版本3.0.6、三台centos7

    • 三个节点固定ip
      192.168.50.120、192.168.50.121、192.168.50.122(作为仲裁节点)

    • 每个节点分别下载解压mongodb-linux-x86_64-3.0.6

    curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.0.6.tgz
    
    • 每个节点分别解压tgz
    tar -zxvf mongodb-linux-x86_64-3.0.6.tgz
    
    • 每个节点分别移动到指定目录
    mv mongodb-linux-x86_64-3.0.6/usr/local/mongodb
    
    • 每个节点分别设置环境变量
    export PATH=mongodb-linux-x86_64-3.0.6/usr/local/mongodb/bin:$PATH
    
    • 每个节点分别创建mongo数据库文件位置
    mkdir /data/db
    
    • 每个节点分别创建mongo日志目录
    mkdir /data/mongo/
    
    • 每个节点分别创建mongodb.conf,文件位置 /etc/mongodb.conf
    #日志文件位置
    logpath=/data/mongo/mongod.log
    # 以追加方式写入日志
    logappend=true
    # 是否以守护进程方式运行
    #fork = true
    # 默认27017
    #port = 27017
    # 数据库文件位置
    #dbpath=/data/mongo/db
    # 启用定期记录CPU利用率和 I/O 等待
    #cpu = true
    # 是否以安全认证方式运行,默认是不认证的非安全方式
    #noauth = true
    #auth = true
    # 详细记录输出
    #verbose = true
    # Inspect all client data for validity on receipt (useful for
    # developing drivers)用于开发驱动程序时验证客户端请求
    #objcheck = true
    # Enable db quota management
    # 启用数据库配额管理
    #quota = true
    # 设置oplog记录等级
    # Set oplogging level where n is
    #   0=off (default)
    #   1=W
    #   2=R
    #   3=both
    #   7=W+some reads
    #diaglog=0
    # Diagnostic/debugging option 动态调试项
    #nocursors = true
    # Ignore query hints 忽略查询提示
    #nohints = true
    # 禁用http界面,默认为localhost:28017
    #nohttpinterface = true
    # 关闭服务器端脚本,这将极大的限制功能
    # Turns off server-side scripting.  This will result in greatly limited
    # functionality
    #noscripting = true
    # 关闭扫描表,任何查询将会是扫描失败
    # Turns off table scans.  Any query that would do a table scan fails.
    #notablescan = true
    # 关闭数据文件预分配
    # Disable data file preallocation.
    #noprealloc = true
    # 为新数据库指定.ns文件的大小,单位:MB
    # Specify .ns file size for new databases.
    # nssize = 
    #复制集名称
    replSet=repl1
    # maximum size in megabytes for replication operation log
    #oplogSize=1024
    # path to a key file storing authentication info for connections
    # between replica set members
    #指定存储身份验证信息的密钥文件的路径
    keyFile=/data/mongo/akey
    
    • 单个节点创建keyfile,之后拷贝到其他从节点
    openssl rand -base64 756 > /data/mongo/akey
    chmod 400 /data/mongo/akey
    chmod 600 /data/mongo/akey
    
    • 每个节点分别启动服务端
    ./mongod -config /etc/mongodb.conf
    
    • 客户端连接mongo
    ./mongo
    
    • 单个节点初始化一个复制集作为主节点
    rs.initiate({_id:'repl1',members:[{_id:1,host:'192.168.50.120:27017'}]})
    
    • 每个节点分别配置管理员账号,角色为内置角色root
    use admin
    db.createUser({user:"moda",pwd:"moda",roles:[{role:"root",db:"admin"}]})
    
    • 使用验证登录
    use admin
    db.auth("moda","moda")
    db.shutdownServer();
    
    • 在主节点上添加从节点
    use admin
    db.auth("moda","moda")
    rs.add('192.168.50.121:27017')
    
    • 在主节点上添加仲裁节点
    use admin
    db.auth("moda","moda")
    rs.addArb('192.168.50.122:27017')
    
    • 验证看一下节点状态
    rs.status();
    rs.conf();
    
    • 主节点添加一条数据
    use moda
    db.moda.insert({"name":"moda"})
    db.moda.find().pretty()
    
    • 登录从节点验证数据
    use admin;
    db.auth("moda","moda");
    rs.slaveOk();
    use moda;
    db.moda.find().pretty();
    
    • 常用命令
    1. rs.initiate():复制集初始化, 例如:
    rs.initiate({_id:'repl1',members:[{_id:1,host:'192.168.50.120:27017'}]}) 
    
    1. rs.reconfig():重新加载配置文件,当只剩下一个secondary节点时,复制集变得不可用,则可以指定force属性强制将节点变成primary,然后再添加secondary节点。例如:
    rs.reconfig({_id:'repl1',members:[{_id:1,host:'192.168.50.121:27017'}]},{force:true});
    
    1. 查看复制集状态
    rs.status()
    
    1. 查看复制情况
    db.printSlaveReplicationInfo()
    
    1. 查看复制集配置
    rs.conf()/rs.config():
    
    1. 在当前连接让secondary可以提供读操作
    rs.slaveOk()
    
    1. rs.add():增加复制集节点,例如:
    rs.add('192.168.50.121:27017') 
    
    1. 指定hidden属性添加备份节点
    rs.add({"_id":3,"host":"192.168.50.121:27017","priority":0,"hidden":true})
    
    1. 指定slaveDelay属性添加延迟节点
    rs.add({"_id":3,"host":"192.168.50.121:27017","priority":0,"slaveDelay":60})
    

    priority:是优先级,默认为1,如果想手动指定某个节点为primary节点,则把对应节点的priority属性设置为所有节点中最大的一个即可

    1. rs.remove():删除复制集节点,例如:
    rs.remove('192.168.50.121:27017')
    
    1. rs.addArb():添加仲裁节点。仲裁节点,只参与投票,不接收数据。例如:
    rs.addArb('192.168.50.122:27017');
    rs.add({"_id":3,"host":"192.168.50.122:27017","arbiterOnly":true})
    
    • 安装出现的问题
    1. -
    2. -
    3. -
    4. 需启动IP:122mongo服务
    • 本文参考文档
    1. 搭建mongo
    1. 搭建复制集

    相关文章

      网友评论

        本文标题:MongoDB3.0.6搭建主从复制集

        本文链接:https://www.haomeiwen.com/subject/xrsvthtx.html