zoukankan      html  css  js  c++  java
  • mongodb高可用集群01---单实例、主从模式、一主多从模式

    本人根据此文章进行学习:http://blog.jobbole.com/72610/

    会不断更新内容主要分为四大模块:

    • mongodb各种方式的部署
    • 常用使用[工作不用就没必要学了,精力有限]
    • 性能优化
    • 故障排除

    很多会和网上资料一样,主要是自己学习不断梳理资料,追求:提及精华

    单实例:

    1)建立mongodb测试文件

    #存放整个mongodb文件

    mkdri-p /data/mongodbtest/single

    #mongodb数据文件

    mkdir /data/mongodbtest/data

    2)mongodb安装

    cd /data/mongodbtest/single
    tar mongodb-linux-x86_64-rhel62-3.0.6.tgz
    mv mongodb-linux-x86_64-rhel62-3.0.6 mongodb

    3)启动单实例mongodb

    /data/mongodbtest/single/mongodb/bin/mongod  --dbpath /data/mongodbtest/single/data

    输出日志如下,表示已成功:

     [initandlisten] db version v3.0.6
     [initandlisten] git version: 1ef45a23a4c5e3480ac919b28afcba3c615488f2
     [initandlisten] build info: Linux ip-10-67-194-123 2.6.32-220.el6.x86_64 #1 SMP Wed Nov 9 08:03:13 EST 2011 x86_64 BOOST_LIB_VERSION=1_49
     [initandlisten] allocator: tcmalloc
     [initandlisten] options: { storage: { dbPath: "/data/mongodbtest/single/data/" } }
     [initandlisten] waiting for connections on port 27017

    Web访问:localhost:28017

    注:第一次启动会有点久

    主从模式:

    1)       ip:192.168.30.131 作为主节点master

    ip:192.168.30.132 作为从节点slave

    2)       master创建文件夹:/data/mongodbtest/master

    slave  创建文件夹:/data/mongodbtest/slave

    3)启动master:

    /data/mongodbtest/single/mongodb/bin/mongod--dbpath /data/mongodbtest/master –master

    输出日志如下,表示已成功:

    [initandlisten] MongoDBstarting :pid=3978 port=27017 dbpath=/data/mongodbtest/master master=1 64-bit host=hadoop03
    ……
    [initandlisten] options: { master: true, storage: { dbPath: "/data/mongodbtest/master" } }

    启动slave:

    /data/mongodbtest/single/mongodb/bin/mongod–dbpath /data/mondbtest/slave –slave –source 192.168.30.131:27017

    输出日志如下,表示已成功:

    [initandlisten] MongoDBstarting :pid=3521 port=27017 dbpath=../slave slave=1 64-bit host=hadoop04
    ……
    [initandlisten] options: { slave: true, source: "192.168.30.131:27017", storage: { dbPath: "../slave" } }
    ……
    [replslave] repl: syncing from host:192.168.30.131:27017

    4)       测试主从复制

    在主节点上连接到终端:

    /data/mongodbtest/single/monodb/bin/mongo 127.0.0.1
    > use test;
    switched to db test
    >db.testdb.insert({"test1":"testvall"})
    WriteResult({ "nInserted" : 1 })
    >db.testdb.find()
    { "_id" : ObjectId("5601085dc618d904c883a5e2"), "test1" : "testvall" }

    检查从主机的数据:

    /data/mongodbtest/single/monodb/bin/mongo 127.0.0.1
    > use test;
    switched to db test
    >db.testdb.find();
    { "_id" : ObjectId("5601085dc618d904c883a5e2"), "test1" : "testvall" }

    从slave主机上查看服务状态:

    >db.printReplicationInfo()
    this is a slave, printing slave replication info.
    source: 192.168.30.131:27017
             syncedTo: Tue Sep 22 2015 15:57:59 GMT+0800 (CST)
             13 secs (0 hrs) behind the freshest member (no primary available at the moment)

    一主多从模式:

    和主从模式一样,只是再添加从主机而已,这里就不多讲了

    总结上述模式的缺陷:

    a)  主节点挂了能否自动切换连接?目前需要手工切换。

    b)  主节点的写压力过大如何解决?

    c)  从节点每个上面的数据都是对数据库全量拷贝,从节点压力会不会过大?

    d)  就算对从节点路由实施路由访问策略能否做到自动扩展?

     

     

  • 相关阅读:
    小心使用宏
    常见文件、目录、路径操作函数
    链表法页框的分配和去配
    获取调试符号文件
    Visual C++ Runtime Error 调试
    HEAP: Free Heap block XXXX modified at XXXX after it was freed
    磁盘操作 API
    【转】浅谈大型网站动态应用系统架构 Mr
    jQuery1.3.1 Tab选项卡 Mr
    spring依赖注入思想 Mr
  • 原文地址:https://www.cnblogs.com/lens/p/4830573.html
Copyright © 2011-2022 走看看