Oracle NoSQL数据库介绍

Oracle的键-值数据库(简称“Oracle NoSQL数据库”)已经更新到了版本2.0。该数据库本质上是一个Berkeley DB的分布式前端,但是它提供了更多的功能。

Oracle NoSQL数据库和Oracle数据库做了深度集成。通过Oracle的外部表功能,可以对NoSQL数据库编写SQL查询,甚至可以连接关系表。同时它还支持Hadoop 以及 Apache的 map-reduce技术。

在运营方面,“它支持SNMP/JMX,能够和Oracle及第三方管理工具集成”。(JMX指 Java管理扩展,大概从Java5之后它便是标准的暴露应用程序状态的方式。)

和MongoDB等流行的数据库不同的是,Oracle NoSQL数据库除了提供最终一致性之外,还提供了绝对一致性。Peter Wayner 解释说:

注意,这个结构使用Oracle级(Oracle-grade)的严肃性存储数据。如果你不想使用由许多其他的NoSQL存储所提供的懒鬼级(slacker-grade)的最终一致性,可以通过Oracle NoSQL在所有复制节点的机器上使用绝对一致性。为此将会牺牲写入性能,当然这取决于你的选择。

顺便说一下,这不仅仅是一个二元决定。你可以在某个、大多数或者所有节点向磁盘发送完数据之后告诉Oracle NoSQL注销该写入方式。文档中将这个特性称之为持久化策略。

如果程序员有时间搭理这些内容,则可以利用其中的一些灵活性。所有的键-值对都有一个版本号,如果你想要在复制时做一些自己的事情那么可以自己查看该版本号。如果你试图提升修改记录时的性能,这对你会有所帮助。

它可以存储通用对象,那些关注性能的人可能想要查看Avro 模式。文档中宣称:

使用Avro模式能够将序列化的值存储到一个空间高效的二进制格式中。除了一个小的内部模式识别符(大小介于1至4个字节之间)之外,每一个存储值都没有任何元数据。每一个键-值对都会存储一个这样的引用。通过这种方式,被序列化的Avro数据格式始终会和序列化它的模式关联,同时开销最小。这种关联对应用程序是透明的,同时内部的模式识别符由AvroCatalog类所提供的绑定管理。应用程序永远不会看见或者直接使用内部的标识符。

NoSQL数据库社区版基于AGPL许可提供。当然也有商业许可的企业版。

查看英文原文:A Look at Oracle’s NoSQL Database

你可能感兴趣的:(Oracle NoSQL数据库介绍)