mongo常用的限制

今天在将stix文件导入mongo数据库时,报出了文档大于16M的情况。小记下mongo常用的限制。

命名限制

  1. 数据库名称是大小写区别的:同时mongo也不允许两个数据库名称仅仅为大小写区别。
  2. 在windows下的数据库名称限制:/. “*<>:|? 并且不能包括空格符。
  3. 在Unix Linux下的数据库名称限制:/. “ 同样不能包括空格符。
  4. 数据库名称长度:64字节
  5. 集合名称限制:必须以下划线或者字母开头,并且不能包括 $,引号,空格符,点号
  6. 字段名称限制:不能包括点号,$,与空格符。

名字空间

  1. 名字空间长度限制:包括数据库与集合名称,总共不能超过123字节
  2. 名字空间数量:mongo为每个数据库保存一个16MB的名字空间文件,dbname.ns ,每个名称占用628字节,因此默认可以支持24000个名字空间(索引也占用一个名字空间)。
  3. 名字空间文件大小:最大不超过2048MB,默认为16MB,可以使用nssize选项进行配置。

Capped Collections

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

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. 索引关键字:该字段的取值不能超过1024字节,否则不能添加到一个索引中。
  2. 集合的最大所有个数:64
  3. 索引名称长度:包括数据库于集合名称总共不超过125字符。
  4. 联合索引最大字段个数:31
  5. 不能联合使用text索引与其他类型索引

复制集

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

参考文档

  1. https://docs.mongodb.com/manual/reference/limits/#limit-bson-document-size