成都心情

  BlogJava :: 首页 ::  :: 联系 :: 聚合  :: 管理 ::
  98 随笔 :: 2 文章 :: 501 评论 :: 1 Trackbacks

前言

业界对持久存储领域的追求从未停止过,为了更方便、更容易地用对象表达我们的思维,开源领域和商业领域都涌现了许多新技术, ORM 的出现恰恰说明了这点。最近一年,业界也在反思,到底 ORM 给我们带来的是便利还是麻烦。矛头指向大名鼎鼎的 Hibernate ,纷纷议论其性能问题,大家似乎要达成这样的共识:“在业务逻辑复杂的地方用 SP ,而一般的 CRUD 还是 Hibernate ”,就连全球知名的 BearingPoint 也有类似看法。下面一个简单的例子,说明了传统 ORM 工具的弊端。让我们考虑一个简单的 Student 对象如清单1


清单1. Student 类

				
public class Student { 
	private String name; 
	private int age; 
	public String getName(){ 
		return name; 
	} 
	public int getAge(){ 
		return age; 
	} 
} 

考虑下面这个场景:找到“年龄小于 20 岁的所有学生”?

使用 ORL 实现如清单2


清单2. ORL 实现

				
String oql = "select * from student in AllStudents where student.age <20"; 
OQLQuery query = new OQLQuery(oql); 
Object students = query.execute(); 

使用 JDOQL 实现如清单3


清单3. JDOQL 实现

				
Query query = persistenceManager.newQuery(Student.class, "age <20"); 
Collection students = (Collection)query.execute(); 

上面的方法都存在一些普遍问题:

  • 现代集成开发环境不会检查内嵌字符串的语义和语法错误。在上面所有查询语句中, age 字段和数值 20 都被认为是数字类型,但是没有一个 IDE 或编译器能检查其实际正确性。如果开发者混淆了查询代码-―比如,改变了 age 字段的名字或类型,将导致――上面所有的查询语句在运行时报错,而不会在编译时提示。
  • 现代敏捷开发技术鼓励不断进行重构来维持清晰和与时俱进的类模型,以便准确重现不断演进的域模型。如果查询代码难于维护,它会延迟决定重构的时间并不可避免的引入低质量代码。
  • 所有列出的查询都直接用 Student 类的私有成员 age,而不是使用它的公共接口 student.getAge(),因此他们都破坏了面向对象封装规则,违反接口和实现应该分离的面向对象法则。
  • 所有的查询都非 100% 的原生。

既然存在如此多的问题, 为什么不直接使用纯面向对象数据库呢?有些开发者可能会说:“它缺乏数学模型的支持, 还不够成熟”。的确, RDBMS 发展了几十年才有今天的成就,已经非常完善了。而技术的革新是无止境的, 故步自封的永远都跟不上变化的脚步。

让我们来简单回顾一下对象数据库的发展史(资料来源于 Wiki 百科全书):“面向对象数据库系统”这一术语第一次出现于 1985 年。著名的研究项目包括:Encore-Ob/Server ( 布朗大学), EXODUS(Wisconsin 大学), IRIS (惠普), ODE ( Bell 实验室), ORION (MCC ) ,Vodak (GMD-IPSI)和 Zeitgeist (Texas Instruments)。其中以 ORION 项目发表的论文数为最多。 MCC 的 Won Kim 将这些论文中最有价值的一部分汇编成书并由 MIT 出版社出版。对象数据库管理系统为面向对象编程语言增加了持久的概念。最早的商品化 ODBMS 出现在 1986 年,是 Servio 公司(现在的 GemStone 公司)和 Ontos 公司推出的。后来(九十年代) Object Design ( ODI )、 Versant 、 Objectivity 、 O2 Technology 、 Poet 、 Ibex 、 UniSQL 和 ADB MATISSE 等公司也加入了这个开拓行列。

而今天,一家来自加州硅谷的开源面向对象数据库公司 db4objects 为我们带来了db4o, 一款性能卓越的纯面向对象数据库,也是我们这篇和后续文章将会介绍的主角。

db4o 为我们带来的是这样一种面向对象的查询方式:

  • 100% 的原生 查询语言应能用实现语言( Java 或 C# )完全表达,并完全遵循实现语言的语义。
  • 100% 的面向对象 查询语言应可运行在自己的实现语言中,允许未经优化执行普通集合而不用自定义预处理。
  • 100% 的类型安全 查询语言应能完全获取现代 IDE 的特性,比如语法检测、类型检测、重构,等等。



 

什么是 db4o

“利用表格存储对象,就像是将汽车开回家,然后拆成零件放进车库里,早晨可以再把汽车装配起来。但是人们不禁要问,这是不是泊车的最有效的方法呢。” – Esther Dyson

db4o 是一个开源的纯面向对象数据库引擎,对于 Java 与 .NET 开发者来说都是一个简单易用的对象持久化工具,使用简单。同时,db4o 已经被第三方验证为具有优秀性能的面向对象数据库, 下面的基准测试图对 db4o 和一些传统的持久方案进行了比较。db4o 在这次比较中排名第二,仅仅落后于JDBC。通过图 1 的基准测试结果,值得我们细细品味的是采用 Hibernate/HSQLDB 的方案和 JDBC/HSQLDB 的方案在性能方面有着显著差距,这也证实了业界对 Hibernate 的担忧。而 db4o 的优异性能,让我们相信: 更 OO 并不一定会牺牲性能。


图1. HSQLDB 基准测试
图1. HSQLDB 基准测试

同时,db4o 的一个特点就是无需 DBA 的管理,占用资源很小,这很适合嵌入式应用以及 Cache 应用, 所以自从 db4o 发布以来,迅速吸引了大批用户将 db4o 用于各种各样的嵌入式系统,包括流动软件、医疗设备和实时控制系统。

db4o 由来自加州硅谷的开源数据库公司 db4objects 开发并负责商业运营和支持。db4o 是基于 GPL 协议。db4objects 于 2004 年在 CEO Christof Wittig 的领导下组成,资金背景包括 Mark Leslie 、 Veritas 软件公司 CEO 、 Vinod Khosla ( Sun 公司创始人之一)、 Sun 公司 CEO 在内的硅谷高层投资人组成。毫无疑问,今天 db4objects 公司是硅谷炙手可热的技术创新者之一。



 


db4o 特性

db4o 的目标是提供一个功能强大的,适合嵌入的数据库引擎,可以工作在设备,移动产品,桌面以及服务器等各种平台。主要特性如下:

  • 开源模式。与其他 ODBMS 不同,db4o 为开源软件,通过开源社区的力量驱动开发 db4o 产品。
  • 原生数据库。db4o 是 100% 原生的面向对象数据库,直接使用编程语言来操作数据库。程序员无需进行 OR 映射来存储对象,大大节省了程序员在存储数据的开发时间。
  • 高性能。 图2 为 db4o 官方公布的基准测试数据,db4o 比采用 Hibernate/MySQL 方案在某些测试线路上速度高出 44 倍之多!并且安装简单,仅仅需要 400Kb 左右的 .jar 或 .dll 库文件。在接下来的系列文章中,我们将只关注在 Java 平台的应用,但是实际上 db4o 毫无疑问会很好地在 .NET 平台工作。

    图2. db4o 官方基准测试数据
    图2. db4o 官方基准测试数据

  • 易嵌入。使用 db4o 仅需引入 400 多 k 的 jar 文件或是 dll 文件,内存消耗极小。
  • 零管理。使用 db4o 无需 DBA,实现零管理。
  • 支持多种平台。db4o 支持从 Java 1.1 到 Java 5.0,此外还支持 .NET 、 CompactFramework 、 Mono 等 .NET 平台,也可以运行在 CDC 、 PersonalProfile 、 Symbian 、 Savaje 以及 Zaurus 这种支持反射的 J2ME 方言环境中,还可以运行在 CLDC 、 MIDP 、 RIM/Blackberry 、 Palm OS 这种不支持反射的 J2ME 环境中。

或许开发者会问,如果现有的应用环境已经有了关系型数据库怎么办?没关系,db4o 的 dRS(db4o Replication System)可实现 db4o 与关系型数据库的双向同步(复制),如图 3 。 dRS 是基于 Hibernate 开发,目前的版本是 1.0 ,并运行在 Java 1.2 或更高版本平台上,基于 dRS 可实现 db4o 到 Hibernate/RDBMS 、 db4o 到 db4o 以及 Hibernate/RDBMS 到 Hibernate/RDBMS 的双向复制。dRS 模型如图3


图3. dRS 模型
图3. dRS 模型

 

 

结论

db4o 因为其开源的理念,以及创新的实现,获得了 Java Pro 2006 读者选择奖。无论从成功案例还是 db4o 本身来看,这款纯面向对象数据库都值得我们关注,从官方论坛反馈情况看,有相当的用户准备把关系型数据库迁移到 db4o 。而最新发布的 5.5 版本,更是把性能再次提升很多。在接下来的文章中,我会继续和大家分享 db4o 给我们带来的这场面向对象数据库风暴。


 

参考资料

学习


讨论

作者简介

Rosen Jiang 来自成都,是 db4o 和 OO 的忠实 fans,是 2005 年 db4o 的 dvp 获得者之一。他正在 J2me 应用中使用 db4o,你可以通过 rosener_722@hotmail.com 和他联系。


张黄瞩,热爱开源软件,熟悉 Java/C/C++ 编程语言,对数据库技术网络技术均感兴趣。你可以通过 zhanghuangzhu@gmail.com 联系他。


Chris 来自香港,热爱开源和 db4o。他创办了中国最火热的 Java 和开源社区 Matrix(http://www.Matrix.org.cn), 你可以通过 chris@Matrix.org.cn 和他联系。


IBM DeveloperWorks(IBM DW) 版权所有!引用、转贴本文应注明本文来自 IBM DW。
posted on 2006-06-15 21:39 Rosen 阅读(5953) 评论(21)  编辑  收藏 所属分类: Versant db4o 中文项目

评论

# re: db4o 之旅(一) 2006-06-15 23:05 艾尘
曾有轻度关注过这东西。
原来有那么多重量级的公司已在使用当中。
看来真的得关注下了。:P  回复  更多评论
  

# re: db4o 之旅(一) 2006-06-16 08:57 sswh
怎样理解这两句话?
-----------------------
根据 db4o 官方公布的基准测试数据(图 2 所示),比采用 Hibernate/MySQL 方案速度高出 44 倍。
-----------------------
最新发布的 5.4 版本,更是把性能再次提升了 11 倍之多
----------------------

这样看来,现在db4o的速度是Hibernate速度的44*11=484倍?
是在玩数字游戏吗?还是搞笑用的??  回复  更多评论
  

# re: db4o 之旅(一) 2006-06-16 09:15 sswh
抱歉我前面的话太尖刻了。只是因为既然写出来,就要有充分的证据来说明,因为关于性能问题,对象数据库和关系数据库哪个更高,好像一直在争论不休。
而我对于上面的未经考证的数字很反感。

总的来说,非常感谢,并期待斑竹的下一篇文章。
  回复  更多评论
  

# re: db4o 之旅(一) 2006-06-16 09:19 野风
现在普遍用的还是关系数据库,对象数据库要成为主流,还有一段时间吧  回复  更多评论
  

# re: db4o 之旅(一) 2006-06-16 09:30 Rosen
@sswh
感谢您的回复,就这个数据的准确性,我马上证实一下。作为开发者,肯定不允许不准确的数字。呵呵  回复  更多评论
  

# re: db4o 之旅(一) 2006-06-16 10:46 江南白衣
第3个user story“在运行时数据库和内存中任何时候都要管理大约 39000 个对象”,才39000条数据,有点access的感觉?  回复  更多评论
  

# re: db4o 之旅(一) 2006-06-16 13:53 Compass
@江南白衣
又不是说只能管理这么多对象  回复  更多评论
  

# re: db4o 之旅(一) 2006-06-16 14:24 江南白衣
当然不止管理这么多对象,但看它的对比对象都是hsqldb,derby,mysql,可见它的目标也是数据量不大的应用。如果上面的测试是在少量数据上完成,那它的性能比hibernate+mysql高很正常,大家的数据库查询都不花多少时间,而Hibernate的转换工作,看过它的代码都知道是极其繁琐的。
所以少数据量时,db4o可能真是一个不错的选择,或者搭建快速演示原型的时候。

另外User Story4还提到“这个实时系统管理架构由超过 30000 个在内存储存的对象和 30 个类组成, 80 TB 的数据最后储存在 Oracle 关系型数据库中, db4o 允许系统每秒处理超过 20 万个对象。 ”
应该是通过db40的dRS来完成的吧-- db4o Replication System,可实现 db4o 与关系型数据库的双向同步(复制),不知道这时候的性能对比又如何,感兴趣ing,因为自己的项目如果要用db4o只能在这种模式下使用.  回复  更多评论
  

# re: db4o 之旅(一) 2006-06-16 14:31 foxty
能支持比较复杂的对象查询么?类似sql这种查询?  回复  更多评论
  

# re: db4o 之旅(一) 2006-06-16 15:54 steeven
并发 百万数据 复杂查询?  回复  更多评论
  

# re: db4o 之旅(一) 2006-06-16 17:12 Rosen
@sswh
我的文章写得有点不准确,5.4 的 11 倍是和 Hibernate/MySQL 相比,在原有的 44 倍的基础上提升,所以 5.4 应该是 Hibernate/MySQL 的 55 倍。对于性能方面的质疑,您可以利用 Polepos 测试工具测试,www.polepos.org。
@foxty
db4o 推荐“原生数据库查询语言”,避免了运行时报错的情况,因为这种查询语言在编译时就能发现错误,完全用对象表达。请参考《持久对象原生数据库查询语言设计白皮书》。  回复  更多评论
  

# re: db4o 之旅(一) 2006-06-16 17:22 Rosen
@江南白衣
白衣提出的问题很有代表性,我开始也在想,为什么不和 Hibernate/Oracle 比较?后来一想,Oracle 和 db4o 目标市场是不一样。db4o 针对的还是那种高可靠性,低维护量的应用,以及移动设备的应用。  回复  更多评论
  

# re: db4o 之旅(一) 2006-06-16 20:13 寒寒
哈哈,继续啊  回复  更多评论
  

# re: db4o 之旅(一) 2006-06-23 10:50 levine
sql用久了,对之类新东西接收心理上接受,实际手却不怎么听话..呵.  回复  更多评论
  

# re: db4o 之旅(一) 2006-07-20 12:09 flyingchen
安装了,但是出了个api文档外什么都看不见:(  回复  更多评论
  

# re: db4o 之旅(一) 2006-07-21 09:19 Rosen
@flyingchen
不会喔,在 lib 文件夹下有 jar 的。  回复  更多评论
  

# re: db4o 之旅(一) 2006-09-07 15:58 Andrew Zhang
性能测试尤其是java程序的性能测试是非常复杂的
文中的多少倍是指在某些测试条件下(某些应该是比较平常的case)
Poleposition给出的数据较为科学,可以看的到db4o的性能在oo编程方便上使用的优势

个人觉得db4o的目标市场和Oracle并不十分冲突,db4o目前最为关注的是嵌入式使用,其内存占用也是非常关键的指标,如果Poleposition benchmark能给出memory footprint的话相信db4o更具说服力  回复  更多评论
  

# re: 开源面向对象数据库 db4o 之旅: 初识 db4o“db4o 之旅(一)” 2006-10-25 16:01 Rosen
@Andrew Zhang
Thx Andrew!  回复  更多评论
  

# re: 开源面向对象数据库 db4o 之旅: 初识 db4o“db4o 之旅(一)” 2006-11-02 17:29 bruce[匿名]
询问:
1 本人在项目中采用db4o作中间临时存储以及状态存储.现在想把报表的大量数据也存储在db4o中,请问db4o存储量上有没有什么限制?

2 我的持久层采用Hibernate实现,是否可以采用dRS将db4o临时存储的报表数据同步复制到Oracle数据库中?

请斑竹以及感兴趣的朋友与我联系!

pytruth1002@gmail.com  回复  更多评论
  

# re: 开源面向对象数据库 db4o 之旅: 初识 db4o“db4o 之旅(一)” 2006-11-23 09:29 itVincent
看了一下他的语法,还有很多可改进的地方的,应该更贴近于现在流行的SQL,才能比较让人接受,学习  回复  更多评论
  

# re: 开源面向对象数据库 db4o 之旅: 初识 db4o“db4o 之旅(一)” 2006-11-23 12:22 Rosen
@bruce[匿名]您好,你就是 bruce@pang.com?抱歉,你的邮件我发不过去。就在这里说吧。
第一个问题,db4o 单个数据库文件的容量上限是 254Gb;第二个问题,可以通过 drs 实现。如果还有问题请上 QQ 群交流 32161114。

@itVincent
对于 SQL 的问题,db4o 承诺在以后的版本中加入对 SQL 92 的支持。我想 db4o 的优势在于面向对象,性能和更低的内存占用。

----------------------------------------------
BTW 通过第三方途径,db4o 可以利用 JPA JDO 进行调用。
http://developer.db4o.com/forums/thread/31248.aspx  回复  更多评论
  


只有注册用户登录后才能发表评论。


网站导航: