1 分区1
2 分区2
3 路由服务器实例-mongos(客户端访问它)
4 配置服务器实例-config

1 分片 cd /d D:\Test\bin1 10001
2 分片 cd /d D:\Test\bin2 10002
3 配置 cd /d D:\Test\bin3 10003
4 路由 cd /d D:\Test\bin4 10004

//启动实例
1 mongod -dbpath "D:\Test\data1" -port 10001 -keyFile "D:\Test\keyfile1\key.txt"
2 mongod -dbpath "D:\Test\data2" -port 10002 -keyFile "D:\Test\keyfile2\key.txt"
3 mongod -dbpath "D:\Test\data4" -port 10003 -keyFile "D:\Test\keyfile3\key.txt"
4 mongos -port 10004 -configdb 127.0.0.1:10003 -keyFile "D:\Test\keyfile4\key.txt" -chunkSize 1

[注意]
集群必须-keyFile安全模式,采用-keyFile模式后-auth不必添加,-keyFile隐含-auth。
-keyFile 文件至少包含6个base64字符并且不大于1K

//配置用户
//4 mongod -dbpath "D:\Test\data4" -port 10004 -keyFile "D:\Test\keyfile\key.txt"

==操作全部针对[路由服务器]==

//添加分片-- 配置路由服务器实例
4 mongo 127.0.0.1:10004
4 use admin
4 db.auth("Mongo3","1000")
4 db.runCommand({"addshard":"127.0.0.1:10001","allowLocal":true})
4 db.runCommand({"addshard":"127.0.0.1:10002","allowLocal":true})
[注意]
使用配置服务器帐号
当路由进程和分片在同一台机器上要指定allowLocal为true

//删除分片-- 配置路由服务器实例 (需执行2次,第一次标记draining:true,第二次删除)
4 db.runCommand({"removeshard":"127.0.0.1:10001"})
[注意]
删除后的分片实例重新添加时,必须把原有数据库删除,否则无法添加(主分片(基片)不允许删除)
4 db.runCommand({"movePrimary": "", to: "" }) //将分片移动到指定的分片(主分片(基片))

//开启数据库分片功能
4 db.runCommand({"enablesharding":"us_user"})
//指定集合中分片片键
4 db.runCommand({"shardcollection":"us_user.user","key":{"userId":1}})
4 db.runCommand({"shardcollection":"us_user.user","key":{"userId":"hashed"}}) //采用哈希分片,数据分布均匀

//查看数据的分片情况
4 db.printShardingStatus() //shards 分片信息/databases.partitioned 是否分片databases.primary 主分片(基片)

//管理分片
4 use config
4 db.shards.find() //查看分片服务器
4 db.databases.find() //查看分片的数据库
4 db.chunks.find() //查看分片信息
4 db.settings.find() //查看分片大小 单位MB
4 db.settings.save({_id:"chunksize",value:1}) //改变分片大小

//分片大小
当数据超出设定大小后自动进行分片操作
设置大小可以在 路由服务器实例 启动时设置 chunkSize 单位MB
4 mongos -port 10004 -configdb 127.0.0.1:10003 -chunkSize 1

=======
单个分片实例只储存部分数据,路由实例不储存数据,只对数据访问进行映射
直接对单个分片实例操作的数据只保存在该分片实例中[参与分片的数据库不建议直接操作]

访问路由服务器只能用配置服务器账户,路由服务器不必设置帐号。
片键建议使用主键,修改单条记录只能根据片键进行修改操作.批量可以不使用片键

未分片数据库,添加数据时会保存到主分片(基片)

MongoDB-分片的更多相关文章

  1. MongoDB 分片管理(不定时更新)

    背景: 通过上一篇的 MongoDB 分片的原理.搭建.应用 大致了解了MongoDB分片的安装和一些基本的使用情况,现在来说明下如何管理和优化MongoDB分片的使用. 知识点: 1) 分片的配置和 ...

  2. MongoDB 分片的原理、搭建、应用

    一.概念: 分片(sharding)是指将数据库拆分,将其分散在不同的机器上的过程.将数据分散到不同的机器上,不需要功能强大的服务器就可以存储更多的数据和处理更大的负载.基本思想就是将集合切成小块,这 ...

  3. MongoDB分片简单实例

    分片 在Mongodb里面存在另一种集群,就是分片技术,可以满足MongoDB数据量大量增长的需求. 当MongoDB存储海量的数据时,一台机器可能不足以存储数据也足以提供可接受的读写吞吐量.这时,我 ...

  4. (转)MongoDB分片实战 集群搭建

    环境准备 Linux环境 主机 OS 备注 192.168.32.13 CentOS6.3 64位 普通PC 192.168.71.43 CentOS6.2 64位 服务器,NUMA CPU架构 Mo ...

  5. 搭建mongodb分片

    搭建mongodb分片 http://gong1208.iteye.com/blog/1622078 Sharding分片概念 这是一种将海量的数据水平扩展的数据库集群系统,数据分表存储在shardi ...

  6. mongodb分片

    在系统早期,数据量还小的时候不会引起太大的问题,但是随着数据量持续增多,后续迟早会出现一台机器硬件瓶颈问题的.而mongodb主打的就是海量数据架构,他不能解决海量数据怎么行!不行!“分片”就用这个来 ...

  7. mongodb 分片群集(sharding cluster)

    实际环境架构 分别在3台机器运行一个mongod实例(称为mongod shard11,mongod shard12,mongod shard13)组织replica set1,作为cluster的s ...

  8. MongoDB基础教程系列--第九篇 MongoDB 分片

    1.分片介绍 分片(sharding)是将数据拆分,将其分散存到不同机器上的过程.MongoDB 支持自动分片,可以使数据库架构对应用程序不可见.对于应用程序来说,好像始终在使用一个单机的 Mongo ...

  9. mongodb分片部署

    Mongodb 分片部署 配置mongodb集群,比如 在3个server上配置 3 shard的Mongodb集群: 架构: 1.每片数据需要3个mongod server,2个为主从数据节点:1个 ...

  10. MongoDB分片原理篇

    MongoDB分片 为什么需要Sharded cluster? MongoDB目前3大核心优势:『灵活模式』+ 『高可用性』 + 『可扩展性』,通过json文档来实现灵活模式,通过复制集来保证高可用, ...

随机推荐

  1. AM335x kernel4.4.12 LCD 时钟翻转设置记录

    TI AM335x kernel 4.4.12 LCD display 时钟翻转记录 因为公司硬件上已经确定LCD 转LVDS 转换芯片上确认以上升沿时钟为基准,所以只能在软件上调整相关东西. 入口在 ...

  2. Linux远程复制命令SCP

    scp test.json savo@yourdomain.com:/usr/share/nginx/test # 以上命令需配置好ssh

  3. Demo中的IOC自定义实现

    在做练习的时候,小小项目,使用IOC控件觉得麻烦,使用工厂觉得不高大上啊,自己写个简陋的依赖注入IOC吧; 控制反转(IOC)是管理映射依赖的的,是依赖倒置(DIP)的实现方式; 依赖倒置(DIP)是 ...

  4. Session的属性

    Session的属性  Session在网络应用中被称为会话.具体到web中的Session指的就是用户在浏览某个网站时,从进入网站到浏览器关闭所经过的这段时间,也就是用户浏览这个网站所花费的时间,因 ...

  5. jeecms3.0.4版本 详解请求如何找到首页(转)

    第一步:发送http://localhost:8080/emisstrade/ 请求 第二步:首先进入配置文件web.xml, <context-param> <param-name ...

  6. 377. Combination Sum IV

    问题 Given an integer array with all positive numbers and no duplicates, find the number of possible c ...

  7. mybatisGenerator 代码自动生成报错 Result Maps collection already contains value for BaseResultMap

    这个错误基本都是mapper.xml有重复生成的代码

  8. Google之Chromium浏览器源码学习——base公共通用库(一)

    Google的优秀C++开源项目繁多,其中的Chromium浏览器项目可以说是很具有代表性的,此外还包括其第三开发开源库或是自己的优秀开源库,可以根据需要抽取自己感兴趣的部分.在研究.学习该项目前的时 ...

  9. Codeforces #380 Subordinates(贪心 构造)

    从前往后扫,找到一出现次数为0的数,从后面找一个出现不为0的数转化而来.设置两指针l, r来处理. #include<cstdio> #include<iostream> #i ...

  10. 11g新特性-使用DNFS

    NFS相信应该都很熟悉了,但是我们对它的性能一直有所诟病.Oracle在10g版本通过允许对数据库文件直接IO引入ASM.在11g版本中,Oracle对NFS提供了类似的增强,为了改进NFS的性能,开 ...