文章翻译自来源:http://docs.mongodb.org/manual/reference/limits/#limit-bson-document-size

一、BSON 文档

1、BSON文档大小,最大限制为16MB,这种限制是为了确保单个文档不会使用过多的RAM,或者在迁移期间不会占用过多的带宽。为了保存大于该限制的文档,mongodb提供了GridFS

当插入的文档大于16MB时将得到如下的错误信息(java客户端):com.mongodb.MongoInternalException: DBObject of size 30836631 is over Max BSON size 16777216

2、文档的最大嵌套数为 100

二、名字空间

1、名字空间长度限制:包括数据库与集合名称,总共不能超过123字节

2、名字空间数量:

mongo为每个数据库保存一个16MB的名字空间文件,dbname.ns
,每个名称占用628字节,因此默认可以支持24000个名字空间(索引也占用一个名字空间)。

3、名字空间文件大小:最大不超过2048MB,默认为16MB,可以使用nssize选项进行配置。

三、索引

1、索引关键字:该字段的取值不能超过1024字节,否则不能添加到一个索引中。

2、集合的最大所有个数:64

3、索引名称长度:包括数据库于集合名称总共不超过125字符。

4、联合索引最大字段个数:31

5、不能联合使用text索引与其他类型索引

四、帽子集合(Capped
Collections)

1、帽子集合的最大文档数:当在创建时候执行最大文档数参数时,该值必须小于2的32次方。若在创建的时候没有指定则文档数不限制。

五、复制集

1、最大的复制集个数:12

2、复制集的投票成员个数:任何时刻最大只有7个成员拥有投票权

六、分片集群

1、在分片环境中不支持的操作:group、eval、$where
$isolated $snapshot geoSearch

2、已存在数据的分片:对于已存在数据的集合,分片的最大支持数据为256GB.
在集群环境之中最大支持的分片集合大约为400GB。精确的阈值根据chunk于数据大小而定。(也就是说,如果要对已有的集合进行分片,那么要在其增长到256G之前进行)。

3、分片集合中的文档更新:所有update、remove操作必须包括分片关键字或者id字段作为查询字段。若没有这些字段将失败。

4、分片集合中的唯一索引:除非唯一索引关键字使用shard
key作为前缀,否则不支持。当使用shardkey作为前缀时,mongo将强制整个key唯一,而非单一字段。
具体可参考:http://docs.mongodb.org/manual/tutorial/enforce-unique-keys-for-sharded-collections/

七、分片关键字限制

1、关键字不能超过512字节。

2、关键字不允许变更:若要修改可采用如下方式:

1)导出所有数据到另外的格式

2)删除原来的分片集合

3)配置新的分片关键字

4)预先分割关键字范围确保实现分布式

5)保存导出的数据到mongo之中。

3、关键字值不允许修改:当一个文档已经插入到分片集合中后,涉及到分片关键字的字段不允许update。

4、单调递增/递减的分片关键字会限制插入效率:

如果使用_id字段作为分片关键字,由于该字段根据time递增,因此这也是一个会影响插入效率的。当向单调递增或递减的分片关键字集合中插入数据时,所有的插入将会导入到同一个chunk同一个分片之中。

加入在集群中以读取和更新占据主导,则这种限制并不影响集群。

为了避免这种限制,使用一个哈希分片关键字或者选择一个非单调递增递减的字段。

八、操作

1、联合多个$in操作:联合多个in表达式,将可能触发联合索引的合并限制。如果符合的item大于等于4000000,mongo将产生“combinatorial limit of $in partitioning of result set exceeded”
错误。

九、命名限制

1、数据库名称是大小写区别的:同时mongo也不允许两个数据库名称仅仅为大小写区别。

2、在windows下的数据库名称限制:/\.
"*<>:|? 并且不能包括空格符。

3、在Unix
Linux下的数据库名称限制:/\.
" 同样不能包括空格符。

字节

、集合名称限制:

必须以下划线或者字母开头,并且不能包括
$,引号,空格符,点号

、字段名称限制:

不能包括点号,$,与空格符。

Mongo限制规则的更多相关文章

  1. Spring Boot-------JPA基础及查询规则

    JPA基础及查询规则 JPA JPA是Java Persistence API的简称,中文名Java持久层API,是JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数 ...

  2. Mongo 专题

    什么是MongoDB ? MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. MongoDB 旨在为WEB应用提供 ...

  3. 封装一个基于NLog+NLog.Mongo的日志记录工具类LogUtil

    封装一个基于NLog+NLog.Mongo的日志记录工具类LogUtil,代码比较简单,主要是把MongoTarget的配置.FileTarget的配置集成到类中,同时利用缓存依赖来判断是否需要重新创 ...

  4. 封装一个基于NLog+NLog.Mongo的日志记录工具类LogUtil,nloglogutil

    封装一个基于NLog+NLog.Mongo的日志记录工具类LogUtil,代码比较简单,主要是把MongoTarget的配置.FileTarget的配置集成到类中,同时利用缓存依赖来判断是否需要重新创 ...

  5. mongo 复制集命令

    1.登录primary2.use admin >rs.add("new_node:port") 或 rs.add({"_id":4,"host& ...

  6. mongo之 前后台创建索引 --noIndexBuildRetry

    在数据量超大的情形下,任何数据库系统在创建索引时都是一个耗时的大工程.MongoDB也不例外.因此,MongoDB索引的创建有两个选择,一个是前台方式,一个是后台方式.那这两种方式有什么差异呢,在创建 ...

  7. mongo学习使用记录1

    1 mongo的安装 1.添加MongoDB安装源 1.添加MongoDB安装源vim /etc/yum.repos.d/mongodb-enterprise.repo 将下列配置项写入文件 [mon ...

  8. 杂记---Mongo的Invalid BSON field name $gte

    1.前言 这几天使用mongo的时候遇到了一个异常:Invalid BSON field name $gte,该问题可能会有很多小伙伴会遇到,因此记录一下解决过程.起因是用JAVA翻译一个其他语言写的 ...

  9. mongo学习1 (转)

    关于mongodb的好处,优点之类的这里就不说了,唯一要讲的一点就是mongodb中有三元素:数据库,集合,文档,其中“集合” 就是对应关系数据库中的“表”,“文档”对应“行”. 一: 下载 上Mon ...

随机推荐

  1. 如何启动jdeveloper中集成的weblogic

    1>运行jdeveloper,打开运行日志,入下图,日志最开始的红框部分就是打开weblogic的命令,将此命令复制出来执行即可打开weblogic 程序员的基础教程:菜鸟程序员

  2. redis高可用 - 主从复制

    工作需要,调研了一下redis的复制实现.在2.8版本之前和之后,复制方式有所不同.2.8之前的复制方式对于初次复制数据没有问题,对于断连接重新复制比较耗性能,因为都是全量复制.2.8之后对断线重连做 ...

  3. 使用Qt Installer Framework制作软件安装包

    概述 Qt Installer Framework(缩写QIF)是Qt官方用于生成软件安装包的工具.包括Qt Creator和Qt Installer Framework自身的安装包都是由这个工具制作 ...

  4. JMS学习之理论基础

    本文代码使用ActiveMq5.6 一.什么是JMS JMS(Java Message Service,Java消息服务)是一组Java应用程序接口(Java API),它提供创建.发送.接收.读取消 ...

  5. 2018年计科五班秋季C语言基础课第1次作业

    ---恢复内容开始--- 1.翻阅邹欣老师博客关于师生关系博客,并回答下列问题: (1)大学和高中最大的不同是没有人天天看着你,请看大学理想的师生关系是?有何感想? 答:我认为是邹欣老师说的健身教练 ...

  6. JS中变量和常量的定义

    var只能声明一个变量,这个变量可以保存任何数据类型的值 ES6之前并没有定义声明常量的方式,ES6标准中引入了新的关键字const来定义常量 使用const定义常量后,常量无法改变 const a= ...

  7. Maven远程发布项目到tomcat

    向tomcat发布项目,每次都要打包传送再运行,非常麻烦.偶然一天发现maven有插件可以直接发布到tomcat.今天把大体过程介绍给大家. 首先在pom中配置tomcat插件: <plugin ...

  8. RabbitMQ的四种ExChange

    在message到达Exchange后,Exchange会根据route规则进入对应的Queue中,message可能进入一个Queue也可能进入对应多个Queue,至于进入哪个Queue或者是说哪个 ...

  9. linux 进阶2--C++读取lua文件中的变量、一维表、二维表

    lua 语言非常灵活,一般把lua 作为脚本文件,会用C++与之进行交互.最重要的是C++代码能读取到脚本中的变量.一维表.二维表. 这样有些参数就可以在lua文件进行更改,而不用重新更改C++代码. ...

  10. 读取IE缓存文件

    使用WebCacheTool项目中的WinInetAPI.cs和Win32API.cs两个类 /// <summary> /// 获取IE缓存文件 /// </summary> ...