嵌入数据库 Berkeley DB 简介

0
PHP Java C/C++ Go 11996 次浏览

ORACLE Berkeley DB(BDB)是一个高性能的,嵌入数据库编程库,和C语言C++JavaPerlPythonTcl以及其他很多语言都有应用程序编程界面。Berkeley DB可以保存任意类型的键/值对,而且可以为一个键保存多个数据。Berkeley DB可以支持数千的并发线程同时操作数据库,支持最大256TB的数据,广泛用于各种操作系统包括大多数Unix类操作系统和Windows操作系统以及实时操作系统

源起

Berkeley DB最先由伯克利加州大学為了移除受到AT&T限制的程式碼,從BSD 4.3到4.4時所改寫的軟體。在1996年時,網景公司希望Berkeley DB的作者群改善函式庫,以配合網景公司所需要的LDAP伺服器,以及在Netscape 瀏覽器,因此促成了Sleepycat Software(在2006年時2月時Sleepycat Software被甲骨文公司所買下)。

Berkeley DB以Sleepycat Public License發行(該授權條款為OSI及FSF所認可的條款)。發行時包括了完整的程式碼、編譯工具、測試套件,以及說明文件。由於良好的程式碼的品質以及工具程式,Berkeley DB常被其他開放原始碼軟體所使用。對於不想使用Sleepycat Public License的開發團體,甲骨文公司也提供了其他付費的授權方式。

Berkeley DB包含有与某些经典Unix数据库编程库兼容的接口,包括:dbmndbmhsearch

 特征

Berkeley DB运行在大多数的操作系统中,例如大多数的UNIX系统, 和windows系统,以及实时操作系统。
Berkeley DB 还拥有对一些老的UNIX数据库,例如dbm, ndbm und hsearch的兼容接口.
对于在java系统中的使用,Berkeley DB提供了一个压缩成jar单个文件的java版本。 这个版本可以运行在java虚拟机上使用,并且拥有和C语言版本相同的所有操作和功能。

Berkeley DB XML,是一个接口,通过它可以实现对XML数据存贮的支持。对XML数据的访问,会使用相应的查询语句如Xquery, Xpath。

Berkeley DB只支持单一的数据结构,它的所有数据包括两个部分:key 和 data.

Berkeley DB原则上是为嵌入式数据库设计的。

 体系结构

Berkeley DB以拥有比Microsoft SQL Server和Oracle等数据库系统而言更简单的体系结构而著称。例如,它不支持网络访问—程序通过进程内的API访问数据库。 他不支持SQL或者其他的数据库查询语言,不支持表结构和数据列。 访问数据库的程序自主决定数据如何储存在记录里,Berkeley DB不对记录里的数据进行任何包装。记录和它的键都可以达到4G字节的长度。

尽管架构很简单,Berkeley DB却支持很多高级的数据库特性,比如ACID 数据库事务处理, 细粒度锁, XA接口,热备份以及同步复制。

 使用Berkeley DB的程式

Berkeley DB是一些轻量级目录访问协议服务器,数据库系统以及其他很多商业和[开源]应用的底层存储系统。下面是使用了Berkeley DB的知名软件的名单。

 MySQL与Berkeley DB

作为全世界最流行的轻量级数据库之一,MySQL也曾经采用过Berkeley DB作为其底层数据引擎,但因Berkeley DB最终被数据库厂商Oracle收购,并且改变了其版权许可协议性质,所以MySQL不再使用其作为数据引擎之一。

请尽量让自己的答案能够对别人有帮助

1个答案

默认排序 按投票排序
0
不错,项目中用到BDB引擎