数据库服务器 PostgreSQL 介绍

jopen 10年前
     <img title="PostgreSQL logo" alt="数据库服务器 PostgreSQL 介绍" src="https://simg.open-open.com/show/65b29314ba4a15a9eea705890b1f3130.png" width="90" height="90" />    <br /> PostgreSQL是一种特性非常齐全的自由软件的对象-关系型数据库管理系统(ORDBMS),它的很多特性正是当今许多商业数据库的前身。本文介绍了PostgreSQL发展的一个简要历程,供大家参考!    <p>今天,如果人们谈论起计算机操作系统,肯定有非常多的人会津津乐道自由软件操作系统Linux,毕竟,众人拾柴火焰高,如今没有任何人敢于忽视 Linux这个自由软件操作系统在我们星球的存在,就连国内比较特殊的环境下,也不断地有各种各样的Linux秀出现让公众,甚至是那些对计算机知之甚少 的群众都能意识到Linux的存在。但是,如果我们说起数据库,可能绝大多数人只会记得有Oracle,IBM DB2,Informix,Sybase,MS SQL Server以及在互联网广为使用的轻量级Mysql,而提到PostgreSQL的名字,可能很多人都会皱起眉毛:“这是什么?”</p>    <p>PostgreSQL是一种特性非常齐全的自由软件的对象-关系型数据库管理系统(ORDBMS),它的很多特性正是当今许多商业数据库的前身。</p>    <p><strong>出身名门</strong></p>    <p>说起PostgreSQL,我们不得不谈Berkeley,也就是中文中的“加州大学伯克利分校”这所大名鼎鼎的大学。老实说,伯克利(BSD)对 计算机科学的贡献可谓巨大,在整个计算机科学的发展史上,几乎到处都有这所学校的研究人员和学生的足迹。只要稍微对计算机技术史有些记忆的人都会记得在 Unix操作系统的发展里程碑上BSD这三个字的分量,然而也许正是由于BSD在系统和网络领域里的光芒太耀眼,掩盖了BSD对计算机技术其他分支的贡 献,而PostgreSQL正是其中之一。</p>    <p>追本溯源地讲,PostgreSQL最早开始于BSD的Ingres项目,这个项目主要是研究关系型数据库技术,早在1970年E.F. Codd就提出了关系模型,从那以后,人类在计算机领域的数据管理就进入了一个新的时期。从此人们开始用抽象的关系语句来描述自己的数据,大大提高了人类 对数据的抽象描述能力。而Ingres项目正是就此进行研究的,它始于1977年,到1985年结束,而其研究成果后来被一家叫Relational Technologies的商业公司拿去做成了商品软件,后来这家公司又被Computer Associates(CA)收购,不知道CA的JASMINE里面是否还有当年Ingres的影子?</p>    <p><strong>新项目Postgres</strong></p>    <p>然后,从1986年开始,BSD的Michael Stonebraker教授领导了称为Postgres的“后Ingres”项目,其主要目的是数据库管理系统的更高级研究,因此而产生了 PostgreSQL的直接前身,Postgres,而PostgreSQL的名字也是从Postgres项目继承过来的。这个项目的成果是非常巨大的, 在现代数据库的许多方面都做出的大量的贡献,比如,面向对象的数据库,部分索引技术,规则,过程和数据库扩展等方面都走在了数据库管理系统的前列。而 且,Stonebraker教授还做出了一件造福全人类的事情,那就是把Postgres放在了BSD版权的保护下,在这个版权的范围里,任何人几乎可以 做任何事情,包括增强它和商业化等。条件只是把BSD的版权声明包括在软件的源程序里。</p>    <p>Postgres在1989年发布了第一个版本,因为是BSD版权,所以很快在各种研究机构和一些公众服务组织里广泛使用起来,由于众多用户使 Postgres的开发变得更多地是维护代码和打补丁,而日益背离了原先的数据库管理系统的研究的目标,到了1994年Postgres在版本4.2的时 候正式终止。而Postgres的许多成果则转化成一个商业公司Illustra,后来Illustra被Informix收购。看到这里,想必大家应该 对Postgres的影响有一些认识了吧!</p>    <p><strong>炎黄子孙的贡献Postgres95</strong></p>    <p>Postgres并没有因为Postgres项目的终止而停止发展,而是获得了一次新生:在1994年,两名伯克利的研究生在做研究生课题的时候, 向Postgres里增加了现代的SQL语言的支持。请不要奇怪,SQL的祖宗是E.F. Codd的关系模型,但是SQL作为语言,一直到1992年才形成真正的国际标准(还是草案),当时称为SQL2,但是人们常称为SQL92。而在那之 前,所以查询语言都是由不同的数据库管理系统自己实现的,比如,在Postgres里原来是用叫Postquel的查询语言;这两位研究生是 AndrewYu和Jolly Chen,看了名字,大家可能会想:“很象中国人的名字嘛”,没错,他们就是黑头发黄皮肤的炎黄子孙,不过很可惜的是他们并没有在中国的(包括台湾省 的)xx大学取得这样的成就。这样,Postgres迎来了1995年,大概是受xxxxxxx95的命名方法的“启发”吧!他们俩把这个版本的 Postgres命名为Postgres95,并且继续发布了几个版本,增强了一些特性。</p>    <p><strong>国际化PostgreSQL</strong></p>    <p>到了1996年,Andrew Yu和Jolly Chen相继离开Postgres95的开发队伍,(Andrew Yu加入了Informix,Jolly Chen继续读书),而在一些自由软件黑客的发起下,Postgres项目又开始了新的历程,最先是由几位加拿大黑客发起,开始了PostgreSQL项 目,后来参与的人越来越多,逐渐成为了一个由近20个国家的近四十名黑客组成的团体共同开发的自由软件项目。PostgreSQL重新把版本号放到了原先 Postgres项目的顺序中去,从6.0开始(Postgres本身到4.2,Postgres95算5.0)。经过五年多的协作开 发,PostgreSQL可以说是目前世界上最先进,功能最强大的自由软件的数据库管理系统。</p>    <p>目前,PostgreSQL的稳定版本到了7.3,具有非常丰富的特性和商业级数据库管理系统的质量。而即将到来的7.4版本又将是一次飞跃,将向高质量大型数据库管理系统的方向又迈进了一步。</p>    <p>在这里,先让我告诉您怎么念PostgreSQL(的确很绕口):Post-gres-Q-L,大概因为大多自由软件开发人员把SQL念做:S-Q-L,而不是IBM常说的(squel)。</p>    <p><strong>特点</strong></p>    <p>PostgreSQL可以说是最富特色的自由数据库管理系统,甚至我们也可以说是最强大的自由软件数据库管理系统。事实上,PostgreSQL的 特性覆盖了SQL-2/SQL-92和SQL-3/SQL-99,首先,它包括了可以说是目前世界上最丰富的数据类型的支持,其中有些数据类型可以说连商 业数据库都不具备,比如IP类型和几何类型等;其次,PostgreSQL是全功能的自由软件数据库,很长时间以来,PostgreSQL是唯一支持事 务、子查询、多版本并行控制系统、数据完整性检查等特性的唯一的一种自由软件的数据库管理系统。直到最近才有Inprise的InterBase以及 SAP等厂商将其原先专有软件开放为自由软件之后才打破了这个唯一。最后,PostgreSQL拥有一支非常活跃的开发队伍,目前的提交人员已经超过三十 人,而且在许多黑客的努力下,PostgreSQL的质量日益提高,也从另外一个侧面上增加了人们使用PostgreSQL的信心,毕竟数据库管理系统不 能象桌面操作系统那样一天宕一次还让人觉得挺满意。</p>    <p>从技术角度来讲,PostgreSQL采用的是比较经典的C/S(client/server)结构,也就是一个客户端对应一个服务器端守护进程的 模式,这个守护进程分析客户端来的查询请求,生成规划树,进行数据检索并最终把结果格式化输出后返回给客户端。为了便于客户端的程序的编写,由数据库服务 器提供了统一的客户端C接口。而不同的客户端接口都是源自这个C接口,比如ODBC,JDBC,Python,Perl,Tcl,C/C++,ESQL 等,同时也要指出的是,PostgreSQL对接口的支持也是非常丰富的,几乎支持所有类型的数据库客户端接口。这一点也可以说是PostgreSQL一 大优点。</p>    <p>说完优点,不能不说几句缺点,不能因为是自由软件而偏袒PostgreSQL,从Postgres开始,PostgreSQL就经受了多次变化。</p>    <p>首先,早期的PostgreSQL继承了几乎所有Ingres,Postgres,Postgres95的问题:过于学院味,因为首先它的目的是数 据库研究,因此不论在稳定性,性能还是使用方便方面,长期以来一直没有得到重视,直到PostgreSQL项目开始以后,情况才越来越好,目 前,PostgreSQL已经完全可以胜任任何中上规模范围内的应用范围的业务。目前有报道的生产数据库的大小已经有TB级的数据量,已经逼近32位计算 的极限。不过学院味也给PostgreSQL带来一个意想不到的好处:大概因为各大学的软硬件环境差异太大的缘故,它是目前支持平台最多的数据库管理系统 的一种,所支持的平台多达十几种,包括不同的系统,不同的硬件体系。至今,它仍然保持着支持平台最多的数据库管理系统的称号。</p>    <p>其次,PostgreSQL的确还欠缺一些比较高端的数据库管理系统需要的特性,比如联机热备份,数据库集群,更优良的管理工具和更加自动化的系统优化功能等提高数据库性能的机制等。</p>    <p>但是,话说回来,PostgreSQL拥有极其强大的扩展能力,你可以很容易地扩展数据类型,内部函数,聚集,操作符等等,而且,别忘了,你拥有所有的源程序,理论上你可以做任何你可以做的事情。因此,很多缺点,在转瞬之间就会消失也是很正常的。</p>    <p>总而言之,PostgreSQL的特性已经完全可以满足绝大部分用户的需要,而且其质量和特性仍然在日新月异地进步着,所以,我们有理由相信在不远的将来,PostgreSQL肯定能够成为一种优秀的,自由的,商业数据库的替代产品。</p>    <p><strong>未来的前景</strong></p>    <p>就目前而言,PostgreSQL的前景非常好,目前的稳定版本是7.3,这个版本在7.2版本的基础上再次做了大量的改进和提高。</p>    <p>7.1是继6.5之后的又一个巨大的变化,她首先引入了预写式日志的功能。这样,事务就拥有了完善的日志机制,可以提供更好的性能,以及还可以实现 更优良的备份和灾难恢复的能力(比如联机热备份和宕机后的自动恢复)。其次是对文本类型的数据段的长度不再限制,从而很大程度上解决了 PostgreSQL的大对象的问题。尤其在如今的web应用盛行的环境下,这个功能几乎立即将PostgreSQL摆到了可以与其他所有类型的数据库竞 争的地位。而且在SQL标准上又有进一步的提高,比如OUTER JOIN的支持等等。</p>    <p>7.2版本在7.1的基础上改进了原来的数据库定期清理工作中排它锁的过程,使数据库维护不再影响数据库的正常使用,同时增强了查询优化的智能,使数据库对索引的使用更加准确;同时还消除了每个安装节点的免维护事务次数的限制;国际化;以及还有大量其他方面的增强。</p>    <p>7.3版本在7.2版本的基础上,继续增强了许多特性,包括可返回结果集的用户函数,模式(schema)的支持,准备好的查询规划,DROP COLUMN的支持,以及vacuum的优化,更好的查询计划器,更好的权限管理系统等。7.3版本在许多现实项目中得到了充分的证明和大量的应用。标志 着PostgreSQL正式成为主流数据库产品之一。</p>    <p>在未来的7.4版本中,我们有望可以看到索引空间的重复利用,优化了的IN子句(大家不用为IN恶劣的性能发愁了),新的前后端协议,更优的聚集函 数。甚至还可能提供windows的本机移植版本和具有相当的热备份功能的PITR(即时恢复)和很多人期待已久的表空间的功能。可以说7.4将是一个完 全胜任7x24应用需求的真正的高端数据库,一个具有开拓企业级应用的数据库。我们有什么理由不欢呼呢?</p>    <p><strong>总结</strong></p>    <p>作为一种数据库管理系统,PostgreSQL并不象Linux与某些商业操作系统相比那样,得到迅速广泛的承认,这一点是可以理解的,Tom Lan曾经有一段话说得实在:“首先,商业数据库系统不象某些商业操作系统那样实在太烂,相反,商业数据库系统的质量还是非常高的,与之相 比,PostgreSQL仍然有一定差距”但同时他也相信“我们已经达到商业级的数据库系统的质量......”。</p>    <p>的确,自由软件的发展具有跳跃性,因为开发者大多是利用空余时间进行开发,当开发者云集的时候,新的东西可能一下子就增加上去;而如果在自由软件运 动的低潮时,因为缺少开发人员,所以可能会有一长段时间的沉寂,而后又会随着社会的发展而出现新的活动。也就是一种螺旋的上升。</p>    <p>因而,我们在面对自由软件的时候,一定要有一点:要相信自己和依靠自己,因为自由软件的发展的确需要每一个爱好者充分发挥自己的聪明才智,同时,也 只有自由软件给你提供了这样的机会——依靠自己的力量改变自己的命运。最后,也只有这样,自由软件之光才能真正照耀我们的世界。<br /> </p>    <p><strong>项目主页:</strong><a href="http://www.open-open.com/lib/view/home/1322486974499" target="_blank">http://www.open-open.com/lib/view/home/1322486974499</a></p>