📄 æ
字号:
前 言
人们很难相信Linux的出现还不到10年。在这样短的时间里,由芬兰的一位研究生作为实验编写的Linux操作系统在性能和使用范围方面不断扩张。同时,Internet的普及加速了Linux的成长。
现在Linux作为一个企业级的基于关键任务的服务器平台迅速流行。自首次全面发行以来,Linux业已证实它是一个稳定的可伸缩的操作系统。然而只是最近,主要的软件供应商们才开始将他们的应用转向Linux平台。这方面最显著的进展出现在1999年,四个一流的数据库供应商(Oracle、Informix、Sybase、IBM)宣布全面支持Linux平台。在此之前,Linux也有其他数据库,但是上述四个重要供应商的加盟使之成为业界注目的中心。
关于本书
本书许多章节讲述各种数据库的安装,如何测试和利用维护数据库所需的关键功能。虽然究竟何种数据库最适合于给定的项目这个问题只能读者自己去判断,但书中还是给出了一些指导以帮助读者进行数据库的选择。
本书的组织方式
本书介绍了几种重要数据库的安装和配置。本书主要用于参考目的,有的读者可能不需要通览全书。书中每一章基本都是独立的,介绍某个特定的数据库。
第1章:Linux操作系统 简要介绍Linux。本章介绍了Linux历史及其背景知识,对不熟悉Linux和开放源代码运动的读者很有帮助。
第2章:基本Red Hat Linux安装 给出最流行的Linux(Red Hat)的详细安装步骤。如果使用的数据库服务器是一个实际的服务器,则建议用新硬件从头开始安装,以便得到可靠的配置。
第3章:在Linux上安装并运行 Oracle Oracle可能是当前市场上最流行的并得到广泛认可的数据库。它具有高度的可伸缩性并且极为可靠。但是,它也极为昂贵,可能不适合小企业。
第4章:在Linux上安装 Informix Informix在可伸缩性和可靠性方面与 Oracle 相近。选择这两个数据库中的哪一个完全取决于个人的偏好。
第5章:在Linux上安装和使用Sybase Sybase有一批非常忠实的追随者。如果你熟悉 Microsoft SQLServer,则Sybase是Linux环境下的一个合理的选择。微软的SQLServer设计与 Sybase的设计极为相近。
第6章:在 Red Hat Linux上安装DB2 Universal Databases 6.1 DB2是一种最未得到正确评价的重要数据库。虽然主要用在大型机上,但DB2转向Linux后功能是很强的,可伸缩性也很好。即使不仔细阅读本章,你也应该不至于忽略将DB2作为一种可行的选择。
第7章:在 Linux上安装MySQL MySQL是最流行的免费数据库。它很容易设置和配置,利用它很容易编制出很好的基于 Web的应用程序。不过对非常大的数据库,它的可伸缩性稍差。
第8章:在Linux上安装和管理Progress Progress一般不为大多数数据库管理员所重视。它通常嵌在第三方应用程序中,但其本身是一个功能很强的数据库。
第9章:Linux上的PostgreSQL PostgreSQL与几个 Linux分发包一道安装。它的源代码与MySQL一样是开放的,对小的数据库应用程序很容易入门。不过其可缩伸性有限。
第10章:开发基于Web的应用程序 给出一个样例数据库应用程序。一旦安装了某个数据库,就可以用它来做许多事情了。
联机Usenet组、白皮书以及用户组是计算机专业人员联网共享知识的宝贵资源。因此,本书中我们还提供了访问Web的有用链接和资源。
Linux环境上的数据库
您可能已经决定在 Linux上实现一个数据库方案。Linux操作系统的稳定性和可靠性很适合数据库。作为一个开放源代码的操作系统,Linux得到很好的支持并不断更新。用户必须一开始就认识到要定期将重要核心版本和对小错误的修正应用到该操作系统,而且对数据库服务器的实际硬件也应该特别关注。应该建立某种冗余机制,特别要考虑按某种独立磁盘冗余阵列(RAID)使用多个磁盘。不同的数据库有不同的配置,应该配备尽可能大的内存;好的数据库安装在不好的机器上功能必然差。
应当从以下几个方面对手头上的操作系统和服务器,提下列几个问题:
■ 你希望数据库完成什么工作?
■ 你的实际环境怎么样:较小、中等或较大?
■ 这是一个基于关键任务的的应用程序吗?
■ 存在这个应用程序的支持需求吗?
本书中介绍的每个数据库都有自身的长处和短处。如果还没有作出决定,或者即使已经作出,都应该考虑一下上述问题。在方案实施以前多点考虑没什么坏处。
在可伸缩性和可靠性方面,Oracle 作为领先者之一有很高的地位。但Oracle还需要高素质的数据库管理员并且要与公司有技术支持合同。这些要求再与Oracle的商用许可证的高成本相结合,使其超出了数据库较小的小企业的需要。Informix的情况也类似。它也是一个功能很强、可靠性很高的数据库,但其所要的价格和技术支持的成本通常太高。
Sybase 是一个很普及适中的方案。它的功能可能没有Oracle和Informix 那么多,但并不缺乏基本功能。它的代价更低,而且如果用户熟悉Microsoft SQLServer,则其配置是非常简单的。Sybase适合于很多应用程序并提供很好的稳定性。DB2也同样如此,但在技术支持方面的挑战性要大些,它的功能和可伸缩性与Oracle一样。不过 DB2 的商业应用代价较小。Progress 也归于 DB2 这一类。
像MySQL和PostgreSQL这样的免费数据库是非常好的入门性解决方案,其成本极低。这些数据库容易实现、容易维护。初学者在本书的帮助下一两天就可以设置好它们并使它们运转起来。这些数据库的主要缺陷是可伸缩性不好。一般免费数据库在管理的记录多于一百万条时会有性能方面的问题。但用这些免费数据库起步,然后再移植到较大的数据库上仍然不失为一种完善的解决方案。将这些数据库的表导出到 SQL,然后导入不同的数据库通常效果很好。如果打算采用这种方案,那么从一开始就花时间设计一个可靠的数据库和好的数据模型会少很多麻烦。这种说法对许多数据库实现都是成立的,但在有数据移植的情况中尤其贴切。
本书是帮助决定哪个数据库最适合要求的书籍,但最终的决定权在您的手中。
有更多的数据库可供选择
当前许多公司正在研究已有数据库的强大应用程序。管理人员和DBA们可从今天的大量数据库中进行选择。SQL的标准化特性使数据的可移植性极强。利用 BLOB(二进制大对象)使得在数据库中存储图像和可执行代码成为可能。相对较新的 XML 技术使以前禁锢在两到三个应用层之后的数据可以直接从 Web上得到。一般来说本书讲述的数据库可归为两种类别:传统数据库与开放源代码数据库。
传统数据库
传统数据库是由较大的软件公司编程和支持的。这种模型的最显著的优点是产品的支持。软件供应商们每年很容易从产品支持、故障排除以及产品升级中取得费用。大多数依赖极大型数据库的公司完全拒绝放弃这种支持模型所提供的额外的收费方式。但传统模型的一个明显的缺点是软件供应商们更改它们的产品和增加新功能很缓慢。在投放到最终用户手中之前,最新技术的开发周期需要数月到数年。一个最显著的缺点就是这些公司和别的公司一样,不愿亮出自己的底牌。单个执照的费用可能阻止了许多用户的使用。供应商经常要进行激烈的竞争,结果是产品出炉过早,经常需要补丁程序。最好的例子就是Oracle 8i。期待已久的这个Oracle版本是为向Internet进军而编写的,但是其中有许多bug。Oracle 8i发行版2处理了这些问题,但已经是一年以后的事了。许多软件公司的情形与此类似。
开放源代码数据库
较新的软件开发模型是开放源代码模型。开放源代码有很大的开发群体优势。一般有一个或几个人对代码负责,他们将整个Internet作为寻找开发人员的大本营。产生出来的软件经常更新和修改。具体软件的最新发行版拥有最新的功能和最新的技术。这当然也会带来缺陷。即,这些功能可能未经过充分的测试,系统管理员必须在新变化和增补方面保持领先,并且需要更高级用户来维护该系统。较大的公司都在回避传统的技术支持和责任并非很有效这个事实。实际上技术支持任务主要落在管理员身上。说实在的,这就是大多数公司的系统被支持的方式。管理员将他们自己的知识以及可从Web站点和新闻组上获得的知识应用到有问题的软件上。
充分利用数据库
在Linux服务器上安装一个数据库是一件很大的事情,但是应该用它来干点什么呢?很大程度上,答案是:“没有限制。”可用它来追踪员工数据、管理客户要求、关联营销数据、改进订单系统的效率,还可以构思和编制许多其他应用程序。
基本特性
所有数据库都支持SQL(结构化查询语言)。这种基本的标准保证了数据库之间的兼容性。某些的数据库可能充分也可能不充分地实现了这个标准,所以,在进行数据库移植时要小心。例如,不要试图将采用了BLOB的Oracle数据库移植到不支持这种对象类型的Postgre SQL数据库上。所有数据库都支持四种基本的SQL结构:SELECT、INSERT、UPDATE、DELETE。此外,所有数据库都应该支持基本用户以及用来创建和管理数据库表和用户权限的表模式。
高级特性
有两种最著名的高级特性,BLOB 和 XML。BLOB 允许在数据库中存储大二进制对象(如图像)。Oracle 和其他几个数据库支持 BLOB。XML(扩展标记语言)是一种新技术。类似于HTML,XML是SGML(标准通用标记语言)的子集。但不像HTML(HTML是一种文档格式标记语言),XML是一种数据符号集标记语言。XML 允许数据直接转储到Web页。如果浏览器或应用服务器支持XML,则可以用最少的编程量格式化和显示数据。当前市场上的大多数数据库都以某种方式支持 XML。
数据库应用
在过去的三年里,Web大为流行,在Web上利用数据库已提上了议事日程。收藏用户和顾客信息、访问个人描述文件、为顾客排序和分类产品信息和数据等将成为驱动电子商务的新标准或新模型。数据开采、数据入口以及购物车(shopping cart)将成为大老板们打高尔夫球时的时髦词汇。
就本书来说,我们给出了汽车销售情景以说明数据库的某些潜在用途。Web服务器在使用 Web上的数据库时是一个关键的因素,我们提供了目前最流行的多个应用的概览。
总之,我们希望读者会发现本书是自己在 Linux上实现各种数据库应用的有用参考书。
本书读者
本书主要是为数据库管理员及那些希望提高自己的技能和了解各种数据库的读者撰写的。我们希望读者阅读本书后,能对一般的数据库设计与实现有更好的理解。本书的优点是有一组照单执行的安装与配置数据库的指令,但是本书尝试让读者更好地理解用做数据库服务器的Linux操作系统。 Syngress 的其他书籍
除本书以外,Syngress Media 公司还出版了许多 IT 专业的书籍。关于新书通告,请访问我们的站点 www.syngress.com。
本书英文书号为:ISBN 1-928994-04-0
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -