设为首页 收藏本站
查看: 1138|回复: 0

[经验分享] MongoDB 3.0 Release Notes

[复制链接]

尚未签到

发表于 2015-7-7 09:33:18 | 显示全部楼层 |阅读模式
  MongoDB 3.0支持WiredTiger存储引擎,提供可插拔存储引擎API,新增SCRAM-SHA-1认证机制,改进explain功能。
可插拔存储引擎API
  允许第三方为MongoDB开发存储引擎
WiredTiger存储引擎
  首次引入WiredTiger存储引擎,目前支持两种存储引擎:

  • MMAPv1,3.0版本之前的存储引擎,也是3.0默认的存储引擎
  • WiredTiger,仅可用于MongoDB 3.0 64位版本
用法
  WiredTiger支持MonoDB的所有特征,复制集和分片集群的成员可以采用不同的存储引擎,需要client采用最新的官方驱动
配置
  详见strorage.wiredTiger相关配置
并发及压缩
  提供文档锁(document-level)和数据压缩,默认使用snappy库压缩集合数据,使用前缀压缩的方式压缩索引
MMAPv1存储引擎
并发
  支持集合锁(collection-level),老版本是数据库锁(database-level),粒度更细,支持更高并发
配置
  为了支持多存储引擎,MMAPv1部分配置选项做了改变:
文档分配策略
  不再支持动态校准的文档分配,同时不建议使用paddingFactor。
MMAPv1默认的文档分配策略是2的N方,忽略usePowerOf2Sizes集合配置,所以未配置noPadding的集合均采用2的N方分配策略。若只有insert和in-place update,可以设置noPadding。
当磁盘空间不足时,写操作仅在需要磁盘空间分配失败时报错,不涉及磁盘分配的删除操作或原地更新操作均可正常执行。
复制集
节点数量
  支持最多50个节点,其中不超过7个投票节点,此特征需要注意所使用的驱动是否支持。
v3.0之前最多支持12个节点,其中不超过7个投票节点。
stepDown过程
  复制集primary节点执行stepDown的过程做了以下改变:

  • 在stepDown之前,尝试终止长时间运行的用户操作,比如建立索引、写操作、map-reduce任务等,因为上述操作可能阻塞stepDown过程
  • 为了避免发生rollback,primary节点将等待有候选资格的secondary节点追赶上primary节点的状态,保证二者状态完全一致。v3.0之前secondary节点同步滞后于primary节点10秒之内即可以执行stepDown。
  • 允许用户设置secondaryCatchUpPeriodSecs参数,如果在指定时间内secondary节点没有赶上primary节点的状态,那么stepDown执行失败, 复制集不会选举新的primary
其他

  • 初始同步建立索引更加高效,使用线程(多线程?有待确认!)批量应用oplog
  • writeConcern w:majority表示投票节点的大多数,一个复制集最多有7个投票节点
  • 更加严格的限制条件,详见官方文档
  • 对于secondary节点上预先存在的集合,不再自动建立缺失的_id索引
分片集群
  做了以下改进:

  • 新增命令sh.removeTagRange(),让带标签的分片集群更容易管理,其作用相对于sh.addTagRange()
  • 提供更加可控的读选项行为。mongos将分析每个操作的读选项,然后按需执行,客户端改变读选项会立即生效。
  • 提供一个新的writeConcern,用于配置chunk迁移操作,适用于balancer、moveChunk命令、cleanupOrplaned命令
  • 完善balancer操作可见性。sh.status()输出结果包含balancer的状态,详见官方文档
安全
  做了以下改进:

  • 新SCRAM-SHA-1用户认证机制
  • 从本机访问的权限限制更加严格,详见官方文档
其他改进
新的查询自检系统(New Query Introspection System)
  为查询计划和查询执行提供粒度更细的自检,改进查询结果的输出格式
日志
  改进日志的可用性,根据组件、操作类型等进行分类,使得分析诊断更加方便,详见官方文档
工具
  所有工具(比如mongodump、mongorestore等)用Go重写并利用一个单独的项目维护

  • mongodump和mongorestore增加新的命令行参数--numParallelCollections,支持多个集合并发导出/导入
  • mongodump新增命令行选项-excludeCollection和--excludeCollectionsWithPrefix,用于排除目标集合
  • mongorestore支持来自标准输入的BSON数据,之前输入仅支持来自BSON文件的数据
  • mongostat和mongotop可使用--json命令行选项生成JSON格式的输出
  • mongoimport mongorestore mongofiles可使用--writeConcern命令行选项配置写选项
  • mongofiles可使用--prefix命令行选项配置GridFS前缀,自定义命名空间,因此一个数据库下可存放多个GridFS命名空间
索引

  • 后台索引建立不再因为目标数据库或集合执行了dropDatabase drop dropIndexes操作而自动中断,上述命令在索引建立过程中执行将报错 a background operation is currentlxiay running
  • 如果用createIndexes命令指定多个索引

    • 该命令只扫描集合一次
    • 如果有索引是前台建立,那么所有的索引都将前台建立

  • 对于分片集合,如果一个索引涵盖片键,那么该索引可以涵盖通过mongos执行的查询,关于Covering a Query,请参考官方文档
查询

  • 地理空间查询,增加查询范围
  • 聚合查询,新增操作符$dateToString用于将日期转换成字符串
  • 新增运算符$eq表示相等条件
参考资料
  Release Notes for MongoDB 3.0
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-84004-1-1.html 上篇帖子: mongodb的serverstatus 下篇帖子: mongodb持久化
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表