zoukankan      html  css  js  c++  java
  • MongoDB:mongodb的分片技术

    MongoDB有另外一种集群技术,就是MongoDB的分片技术。

    原创文章,转载请注明出处:http://blog.csdn.net/jessonlv/article/details/17956085

    一、MongoDB的分片

    MongoDB采用将集合进行拆分,然后将拆分的数据分别均摊到不同的片上的一种解决方案。

    下面我们看下结构图:


    人脸:代表客户访问端

    mongos:“片键”是拆分的依据,按照什么样的键值进行拆分集合...mongos就是一个路由器,它会根据管理员设置的“片键”将数据分摊到自己管理的mongod集群中,数据和片的对应关系以及相关的配置信息保存在“config服务器”上。

    mongod:数据库实例。

    二、实际操作下

    首先我们准备四个mongodb


    1、开启config服务器

    mongos要把mongod之间的配置信息放在config里

    config
    mongod --dbpath=F:mongodbin --port 1111

    2、开启mongos服务器

    开启mongos服务器,同时指定config,在此我们开启我F盘的mongodb2,端口指定为2222.

    mongos
    mongos --port 2222 --configdb=127.0.0.1:1111


    3、开启mongod

    在此对应我F盘的mongdb3、mongodb4,端口分别为3333、4444

    mongod --dbpath=F:mongodb3in --port 3333
    mongod --dbpath=F:mongodb4in --port 4444

    三、进行配置

    1、根据结构图所知,客户是直接和mongos打交道的,我们直接连接mongos服务器,将端口为3333、4444的mongod服务器添加分片到mongos。

    mongo 127.0.0.1:2222/admin
    db.runCommand({"addshard":"127.0.0.1:3333",allowlocal:true})
    db.runCommand({"addshard":"127.0.0.1:4444",allowlocal:true})
    开启test库的分片功能

     mongos> use admin 
        switched to db admin
        mongos> db.runCommand({"enablesharding":"test"})
        { "ok" : 1 }
     mongos> db.runCommand({"shardcollection":"test.user","key":{"_id":1}})
      { "collectionsharded" : "test.user", "ok" : 1 }

       ①:开启数据库分片功能,命令很简单 enablesharding(),这里我就开启test数据库。

       ②:指定集合中分片的片键,这里我就指定为user._id字段。


    四 查看效果

    用命令:db.printShardingStatus() 查看就行。


  • 相关阅读:
    Android内存优化5 了解java GC 垃圾回收机制3
    一起刑事案件法庭辩护 z
    辩护技巧总结——律师在刑事辩护中应注意的几个问题 z
    证据对抗、证据链标准 z
    里德九步审讯法 z
    WCF服务在高并发情况下报目标积极拒绝的异常处理 z
    C#EasyHook例子C# Hook 指定进程C#注入指定进程 z
    玄机论坛Socket类库源码 当前版本 2.6.3 更新日期:10-09/2015 z
    庭审全程文字实录 z
    庭审精彩语录整理 z
  • 原文地址:https://www.cnblogs.com/jessonlv/p/4388001.html
Copyright © 2011-2022 走看看