NoSQL,泛指非关系型的数据库。算法
关系数据库,是创建在关系模型基础上的数据库。
数据库
这里提到了关系模型,
缓存
关系模型是1970年由E.F.Codd提出的。安全
它和层次、网状模型相比,有如下特色:服务器
1.数据结构简单(二维表格)网络
2.扎实的理论基础。数据结构
a.关系运算理论架构
b.关系模式设计理论异步
简单来讲,关系模型指的就是二维表格模型,而一个关系型数据库就是由二维表及其之间的联系所组成的一个数据组织。分布式
对于NoSQL并无一个明确的范围和定义,可是他们都广泛存在下面一些共同特征:
不须要预约义模式:不须要事先定义数据模式,预约义表结构。数据中的每条记录均可能有不一样的属性和格式。当插入数据时,并不须要预先定义它们的模式。
无共享架构:相对于将全部数据存储的存储区域网络中的全共享架构。NoSQL每每将数据划分后存储在各个本地服务器上。由于从本地磁盘读取数据的性能每每好于经过网络传输读取数据的性能,从而提升了系统的性能。
弹性可扩展:能够在系统运行的时候,动态增长或者删除结点。不须要停机维护,数据能够自动迁移。
分区:相对于将数据存放于同一个节点,NoSQL数据库须要将数据进行分区,将记录分散在多个节点上面。而且一般分区的同时还要作复制。这样既提升了并行性能,又能保证没有单点失效的问题。
异步复制:和RAID存储系统不一样的是,NoSQL中的复制,每每是基于日志的异步复制。这样,数据就能够尽快地写入一个节点,而不会被网络传输引发迟延。缺点是并不老是能保证一致性,这样的方式在出现故障的时候,可能会丢失少许的数据。
BASE:相对于事务严格的ACID特性(ACID,指数据库事务正确执行的四个基本要素的缩写。包含:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)。),NoSQL数据库保证的是BASE特性。BASE是最终一致性和软事务。
NoSQL数据库并无一个统一的架构,两种NoSQL数据库之间的不一样,甚至远远超过两种关系型数据库的不一样。能够说,NoSQL各有所长,成功的NoSQL必然特别适用于某些场合或者某些应用,在这些场合中会远远赛过关系型数据库和其余的NoSQL。
NoSQL数据库在如下的这几种状况下比较适用:一、数据模型比较简单;二、须要灵活性更强的IT系统;三、对数据库性能要求较高;四、不须要高度的数据一致性;五、对于给定key,比较容易映射复杂值的环境。
这一类数据库主要会使用到一个哈希表,这个表中有一个特定的键和一个指针指向特定的数据。Key/value模型对于IT系统来讲的优点在于简单、易部署。可是若是DBA只对部分值进行查询或更新的时候,Key/value就显得效率低下了。 举例如:Tokyo Cabinet/Tyrant, Redis, Voldemort, Oracle BDB.
典型应用场景
内容缓存,主要用于处理大量数据的高访问负载,也用于一些日志系统等等。
数据模型
Key 指向 Value 的键值对,一般用hash table来实现
强项
查找速度快
弱项
数据无结构化,一般只被看成字符串或者二进制数据
这部分数据库一般是用来应对分布式存储的海量数据。键仍然存在,可是它们的特色是指向了多个列。这些列是由列家族来安排的。如:Cassandra, HBase, Riak.
典型应用场景
分布式的文件系统
数据模型
以列簇式存储,将同一列数据存在一块儿
强项
查找速度快,可扩展性强,更容易进行分布式扩展
弱项
功能相对局限
文档型数据库的灵感是来自于Lotus Notes办公软件的,并且它同第一种键值存储相相似。该类型的数据模型是版本化的文档,半结构化的文档以特定的格式存储,好比JSON。文档型数据库能够看做是键值数据库的升级版,容许之间嵌套键值。并且文档型数据库比键值数据库的查询效率更高。如:CouchDB, MongoDb. 国内也有文档型数据库SequoiaDB,已经开源。
典型应用场景
Web应用(与Key-Value相似,Value是结构化的,不一样的是数据库可以了解Value的内容)
数据模型
Key-Value对应的键值对,Value为结构化数据
强项
数据结构要求不严格,表结构可变,不须要像关系型数据库同样须要预先定义表结构
弱项
查询性能不高,并且缺少统一的查询语法。
图形结构的数据库同其余行列以及刚性结构的SQL数据库不一样,它是使用灵活的图形模型,而且可以扩展到多个服务器上。NoSQL数据库没有标准的查询语言(SQL),所以进行数据库查询须要制定数据模型。许多NoSQL数据库都有REST式的数据接口或者查询API。如:Neo4J, InfoGrid, Infinite Graph.
典型应用场景
社交网络,推荐系统等。专一于构建关系图谱
数据模型
图结构
强项
利用图结构相关算法。好比最短路径寻址,N度关系查找等
弱项
不少时候须要对整个图作计算才能得出须要的信息,并且这种结构不太好作分布式的集群方案。
尽管大多数NoSQL数据存储系统都已被部署于实际应用中,但概括其研究现状,还有许多挑战性问题。
已有key-value数据库产品大可能是面向特定应用自治构建的,缺少通用性;
已有产品支持的功能有限(不支持事务特性),致使其应用具备必定的局限性;
已有一些研究成果和改进的NoSQL数据存储系统,但它们都是针对不一样应用需求而提出的相应解决方案,如支持组内事务特性、弹性事务等,不多从全局考虑系统的通用性,也没有造成系列化的研究成果;
缺少相似关系数据库所具备的强有力的理论(如armstrong公理系统)、技术(如成熟的基于启发式的优化策略、两段封锁协议等)、标准规范(如SQL语言)的支持。
目前,HBase数据库时安全特性最完善的NoSQL数据库产品之一,而其余的NoSQL数据库多数没有提供内建的安全机制,但随着NoSQL的发展,愈来愈多的人开始意识到安全的重要,部分NoSQL产品逐渐开始提供一些安全方面的支持。
随着云计算、互联网等技术的发展,大数据普遍存在,同时也呈现出了许多云环境下的新型应用,如社交网络网、移动服务、协做编辑等。这些新型应用对海量数据管理或称云数据管理系统也提出了新的需求,如事务的支持、系统的弹性等。同时云计算时代海量数据管理系统的设计目标为可扩展性、弹性、容错性、自管理性和“强一致性”。目前,已有系统经过支持可随意增减节点来知足可扩展性;经过副本策略保证系统的容错性;基于监测的状态消息协调实现系统的自管理性。“弹性”的目标是知足Pay-per-use 模型,以提升系统资源的利用率。该特性是已有典型NoSQL数据库系统所不完善的,但倒是云系统应具备的典型特色;“强一致性”主要是新应用的需求。