我们在最近的一篇文章中探讨了 NoSQL 和 NewSQL之间的基本区别。 现在让我们通过观察开发人员真正关心的问题来剖析其差异:
镇巴ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为成都创新互联公司的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:028-86922220(备注:SSL证书合作)期待与您的合作!
[[191564]]
让我们回顾一下NoSQL和NewSQL之间四个有明显差异的领域,并回顾一下一些使用NoSQL技术,但可能不是***选择的用例。
NoSQL数据库的四个缺点
不要让我们产生误解,NoSQL数据库对于许多工作负载和应用程序是非常有优势的,但在四个方面,NoSQL的缺点是很明显的。
可扩展性
当NoSQL产品用来实现以满足诸如Google,Facebook和Twitter等与生俱来的网络公司的可扩展性需求时,它们开始引起注意。 这些公司要处理大量来自无数来源的非结构化数据:网络搜索,移动设备,用户状态更新,评论流等。
在这些用例中,最重要的考虑是可扩展性:数据库必须大规模扩展。 SQL数据库的僵硬模式和交互性被视为枷锁,并且在传统RDBMS上扩展的成本也被认为是不可行的。
在廉价的硬件商品上向外扩展的能力是很关键的。 如果你的用例需要横向扩展***数据源,NoSQL可能是正确的选择 --- 除非你要对数据进行实时操作。
虽然传统的关系数据库系统提供了扩展选项 ---- 以非常显著的成本 ---- 许多NewSQL系统被设计为解决可扩展性挑战,首先使用NoSQL来解决,同时保留传统RDBMS的事务性和交互性。
一个很好的替代方案是内存中,大规模并行的SQL关系数据库,它在廉价的硬件商品上线性扩展。 数据库应该是云友好的,并且能够通过扩展来满足云操作的需求。 应该将其设计为具有高性能和低延迟,具有无共享,本地群集,云友好的架构,从而实现高可用性,可冗余和容错性。
可用性
大多数NoSQL系统是为可用性设计的,CAP-定理>
这个由Apache Cassandra做出的著名的设计决策是基于这样一个观点,即数据总是可以访问比数据立即正确更重要。 毕竟,理由是,谁真的关心一个Tweet是否真的按照发布的顺序实时显示? 最终,它将以正确的顺序显示,但不一定非得立即正确显示。
在某些用例中,最终的一致性是可以接受的。 但是在许多情况下,例如当您需要立即作出决定时...
... EC(和NoSQL)就不是一个好的选择。
一些NewSQL系统允许用户能够将一致性级别调低。 例如,MemSQL支持弱隔离(ACID中的“I”)来提高查询延迟。 为了可用性而牺牲正确答案,这对分析型(OLAP)工作负载可能是有意义的,但对事务型(OLTP)工作负载就变得无关紧要了。
一致性(例如,兼容ACID事务,正确答案)
NoSQL系统被设计为可用性(见上文)。 这个选择意味着他们无法提供CAP定理>
因此,NoSQL系统选择AP - 它们是可用性和分区容错性。 这使得NoSQL对于需要强一致性的应用程序或用例来说是一个糟糕的选择:
典型的CAP定义说:你不可能同时满足这三个特性。
一个更实际的方式来考虑CAP:面对网络分区,您不能总是具有***的一致性和100%的可用性。 您应该相应地做出规划。
快速请求-响应应用程序
现代请求-响应式风格的应用程序大量发生:
这些事件在世界各地每天发生数百万次。 电信,金融服务,在线游戏,广告技术等行业的供应商需要适应这些事件的变化和速度。 他们需要一个可扩展的,事务性一致的解决方案。
文章题目:4种不适合使用NoSQL数据库的场景
转载注明:http://www.mswzjz.cn/qtweb/news15/9615.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能