当前位置: 首页 > 编程笔记 >

关于NoSQL之MongoDB的一些总结

林礼骞
2023-03-14
本文向大家介绍关于NoSQL之MongoDB的一些总结,包括了关于NoSQL之MongoDB的一些总结的使用技巧和注意事项,需要的朋友参考一下

NoSQL已经流行了很长一段时间,那么究竟是什么场景下你才更需要用到这些“新兴事物”,就比如MongoDB?下面是一些总结:

你期望一个更高的写负载

默认情况下,对比事务安全,MongoDB更关注高的插入速度。如果你需要加载大量低价值的业务数据,那么MongoDB将很适合你的用例。但是必须避免在要求高事务安全的情景下使用MongoDB,比如一个1000万美元的交易。

不可靠环境保证高可用性

设置副本集(主-从服务器设置)不仅方便而且很快,此外,使用MongoDB还可以快速、安全及自动化的实现节点(或数据中心)故障转移。

未来会有一个很大的规模

数据库扩展是非常有挑战性的,当单表格大小达到5-10GB时,MySQL表格性能会毫无疑问的降低。如果你需要分片并且分割你的数据库,MongoDB将很容易实现这一点。

使用基于位置的数据查询

MongoDB支持二维空间索引,因此可以快速及精确的从指定位置获取数据。

非结构化数据的爆发增长

给RDBMS增加列在有些情况下可能锁定整个数据库,或者增加负载从而导致性能下降,这个问题通常发生在表格大于1GB(更是下文提到BillRun系统中的痛点——单表格动辄几GB)的情况下。鉴于MongoDB的弱数据结构模式,添加1个新字段不会对旧表格有任何影响,整个过程会非常快速;因此,在应用程序发生改变时,你不需要专门的1个DBA去修改数据库模式。

缺少专业的数据库管理员

如果你没有专业的DBA,同时你也不需要结构化你的数据及做join查询,MongoDB将会是你的首选。MongoDB非常适合类的持久化,类可以被序列化成JSON并储存在MongoDB。需要注意的是,如果期望获得一个更大的规模,你必须要了解一些最佳实践来避免走入误区。

BillRun——使用MongoDB的账单系统|2014年2月MUG IL(来自oc666)现实用例学习:账单

在上一次的ILMUG上,Ofer Cohen提出了BillRun,一个下一代基于MongoDB的开源账单解决方案。这个账单系统已被增速最快的以色列移动电话运营商采用,每月处理超过5亿的CDR(通讯记录),Ofer分享了该系统如何利用MongoDB的优势:

PPT请访问Slide Share

弱数据结构模式允许系统快速引入新的CDR类型,BillRun负责托管所有的数据。BillRun系统已经管理了TB级的表格,I/O性能受限于新字段的增加及数据体积的增长。快速副本集允许更简单地设置多数据中心DRP和HA方案。分片允许I/O超预算时的线性横向扩展。在CDR插入达到2000个每秒时,MongoDB非常适用于高写入系统。同时,你完全可以使用findAndModify(会影响性能)以及2阶段提交(应用程序级别)来解决事务问题。面向开发者的查询允许优雅查询的编写。基于位置允许更好的分析用户使用情况,从而更好地制定移动电话基础设施的投入点。

总结

MongoDB是个非常不错的工具,但是只有在适合的场景下才能爆发出压倒性优势,BillRun就是一个不错的用例。

以上所述就是本文的全部内容了,希望大家能够喜欢。

 类似资料:
  • 本文向大家介绍C# 关于AppDomain的一些总结,包括了C# 关于AppDomain的一些总结的使用技巧和注意事项,需要的朋友参考一下 前言 一直想写一个这样的程序:与其它的程序完全解耦,但可以动态的加载其它程序,并执行其中的特定方法,执行完后可以卸载,完全不影响该程序本身。最近无意间发现了 C# 中 AppDomain,再加上反射,感觉就是我所需要的。 基本概念 应用程序域为安全性、可靠性、

  • 主要内容:1.NoSql是什么?,2.NoSql数据类型,3.NoSql数据库的分类,4.NoSql的优点,5.说明1.NoSql是什么? Nosql = not only sql,意即“不仅仅是sql”,泛指非关系型数据库。这些类型的数据存储不需要固定的模式(当然也有固定的模式),无需多余的操作就可以横向扩展。 说到非关系型数据库,就要简单的介绍一下关系型数据库,是建立在关系模型基础上的数据库,借助于集合代数等数学概念和方法来处理数据库中的数据,我们平常使用的数据库,像MySQL,Oracle

  • 本文向大家介绍关于JavaScript数组去重的一些理解汇总,包括了关于JavaScript数组去重的一些理解汇总的使用技巧和注意事项,需要的朋友参考一下 前言 做前端开发几年,在项目中用到数组去重的机会倒不是很多,但是在面试的时候却经常被问到,个人理解,这道题真正考的是对JavaScript的基础的掌握,因为有很多种方式可以做到。这次就根据这道题,将相关的知识理解透彻。 一、ES6中的new S

  • 我有以下结构: 一些经理阶层 更新: 我更改了我的类,但现在dao对象为空。

  • 本文向大家介绍关于 angularJS的一些用法,包括了关于 angularJS的一些用法的使用技巧和注意事项,需要的朋友参考一下 AngularJS 事件指令: 和ng-click一样,都是给dom绑定事件的 需要注意的是,使用事件对象的时候,需要在ng-click等指令里传入$event,如: 表单指令 当值发生改变的时候就会有用 有value值的一些个标签,能ng-model的,才能用哟 必

  • 1.首先,我想确认一下从编程的角度,我们有“静态类型检查”和“动态类型检查,对把? 2.一般情况下我们用typescript做静态类型检查,检查源码里面自定义数据类型,对把? 3.那么,我们做的所谓的动态类型检查是不是指的那些库,比如Joi,ajv什么的,比如你点击一个按钮,然后调这个库来检查一个obj的schema,如果类面的key value类型都能对的上,我们就通过,如果类型对不上,我们就报