为什么企业依赖于 NoSQL

作者 : 开心源码 本文共1958个字,预计阅读时间需要5分钟 发布时间: 2022-05-12 共152人阅读

假如你关注大数据科技动向,你对 NoSQL 肯定不陌生,NoSQL 是一个分布式数据库。在过去时间,数据存储一直关系型数据库天下,有着良好的控制并发操作、事务功能。尽管RDBMS很优秀,但是随着时间的推移就出现了两个关系数据库处理不了的问题:快速增长的数据规模和日渐复杂的数据模型。结果,我们看到了 NoSQL 数据库的兴起。

image

一、关系数据库不足

实际上,从 1979 年 Oracle 发布了第一个版本,这些数据库被设计为在单个服务器上运行,并且越大越好。而且添加这些数据库容量的唯一方法是更新服务器解决器、内存和存储,数据存储代价不断升高。随着互联网的数据呈指数级增长和 Web 应用程序的兴起,数据模型日渐复杂,关系数据库难以支撑,NoSQL 数据库也由此孕育而生。在 2006 年谷歌发布了 Bigtable 研究论文,在 2007 年亚马逊发布了 Dynamo 研究论文。而这些新的数据库旨在满足新一代企业要求:需要敏捷开发并支持任意规模运作。

二、敏捷开发

当今是以体验为中心的数字经济,企业如何保持竞争力,那么必需进行创新。因为这项创新的核心是现代 Web、移动和物联网应用程序的开发,因而开发人员必需高频提供应用程序和服务。速度和敏捷性都至关重要,由于这些应用程序的发展速度远远超过 ERP 等传统应用程序。而关系数据库是却不能很好满足于它,由于它们的固定数据模型不能很好地支持敏捷开发。

敏捷开发的核心准则是适应不断变化的应用程序需求:当需求发生变化时,数据模型也会发生变化,这是关系数据库的难以克服的问题,由于关系数据库的模型是固定的,并预先定义好的。因而,当要更改数据模型,开发人员不得不修改当初设定好的数据库结构,以适应新的需求。这会减慢或者中止开发,不仅由于它是一个手动,耗时的过程,而且还会影响其余应用程序和服务。

image

相比之下,NoSQL 文档 数据库完全完美支持这点,由于它是无模式的,没有强制定义数据必需建模。相反,它遵循应用程序和服务。使用 NoSQL,数据模型由应用程序模型定义。应用程序和服务将数据建模作为对象。

image

三、如何支持任意规模运作

为了支持以指数增长的客户和数据 – 数百到数千到数百万客户,以及千兆字节到数TB的数据操作,应用程序和服务不得不进行扩展以保持性能,并且必需有效地运行。

对于扩展关系数据库而言,这是一个问题,例如,使用 Oracle ,使用 RAC 技术进行扩展就需要大量组件,昂贵且不完全可靠。因而,有效扩展和按需扩展的能力是一项挑战。它会变得越来越昂贵,由于必需购买更大更强的服务器以容纳更多客户和更多数据。此外,假如必需使数据库脱机以执行硬件更新,则可能导致停机。

然而,分布式 NoSQL 数据库利用廉价硬件进行扩展, 只要增加更多服务器就可增加更多资源。扩展能力使企业能够通过以下方式更有效地扩展:

1、不需要为满足部署而买相对称的硬件

2、利用较便宜的硬件进行拓展;

3、按需扩展,无需停机。

image

四、NoSQL 常见存储方式

NoSQL 常见有三种存储方式:键值存储、面向文档的数据库和面向列的数据库。接下来说明这几种存储方式以及数据库代表。

image

键值存储

代表:Redis、memcached

键值存储是 NoSQL 最常见存储方式,通过 key-value 形式保存数据,高速访问数据。而且根据保存时效也分为临时性、永久性和两者兼备。

面向文档的数据库

代表:MongoDB、CouchDB

面向文档的数据库数据结构要求不是很严格,不定义表结构而且可以使用复杂的查询条件

面向列的数据库

代表:HBase

面向列的数据库以列为单位进行存储,这里的列式存储其实说的是列族存储,它将数据表存储为数据列而非行的形式。列族存储优势:快速查询,易拓展,但功能相对局限。

五、NoSQL 对于事务的支持?

在这里有一个误区,因为分布式事务需要分布式协作,所以似乎必需在性能可扩展性和分布式事务支持之间进行权衡。

耶鲁大学的一名副教授 Daniel Abadi 认为这个想法是错的,可拓展的分布式系统也是可以实现事物。他提出了一个新的权衡策略,具体是在公平性、隔离性和吞吐量(FIT)三者之间进行取舍。
换句话说,有两种方法构建出具有分布式事务吞吐量的可扩展系统:

1、放弃隔离性

当放弃隔离性,一个事物是不会跟其余事物有冲突,就无需等待协作即可以完成了。而且也有一类数据束缚可以确保在弱隔离下正确性。

2、放弃公平性

通过设定分布式协作的顺序最小化两者之间的时间重叠,从而减轻二者之间的相互影响,在此公平下找到最合适时间进行协作。

六、小结

构建和运行这些大规模交互式应用程序创立了一组新的技术要求。新的技术架构需要比以往更加灵活,并且需要一种能够适应史无前例的规模、速度和数据可变性的实时数据管理方法。关系数据库无法满足这些新要求,这就使得 NoSQL 逐步流行起来。

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » 为什么企业依赖于 NoSQL

发表回复