ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 读《Oracle 9i&10g编程艺术》记录--- 定义数据库和实例

读《Oracle 9i&10g编程艺术》记录--- 定义数据库和实例

原创 Linux操作系统 作者:andyxu 时间:2009-07-16 10:38:04 0 删除 编辑

在Oracle领域中有两个词很容易混淆,这就是“实例”(instance)和“数据库”(database)。作为Oracle术语,这两个词的定义如下:
􀂉 数据库(database):物理操作系统文件或磁盘(disk)的集合。使用Oracle 10g的自动存储管理(Automatic Storage Management,ASM)或RAW分区时,数据库可能不作为操作系统中单独的文件,但定义仍然不变。
􀂉 实例(instance):一组Oracle后台进程/线程以及一个共享内存区,这些内存由同一个计算机上运行的线程/进程所共享。这里可以维护易失的、非持久性内容(有些可以刷新输出到磁盘)。就算没有磁盘存储,数据库实例也能存在。也许实例不能算是世界上最有用的事物,不过你完全可以把它想成是最有用的事物,这有助于对实例和数据库划清界线。

实例就是一组操作系统进程(或者是一个多线程的进程)以及一些内存。这些进程可以操 作数据库;而数据库只是一个文件集合(包括数据文件、临时文件、重做日志文件和控制文件)。在任何时刻,一个实例只能有一组相关的文件(与一个数据库关 联)。大多数情况下,反过来也成立:一个数据库上只有一个实例对其进行操作。不过,Oracle的真正应用集群(Real Application Clusters,RAC)是一个例外,这是Oracle提供的一个选项,允许在集群环境中的多台计算机上操作,这样就可以有多台实例同时装载并打开一个数据库(位于一组共享物理磁盘上)。由此,我们可以同时从多台不同的计算机访问这个数据库。Oracle RAC能支持高度可用的系统,可用于构建可扩缩性极好的解决方案。

一个实例在其生存期中最多只能装载和打开一个数据库。要想再打开这个(或其他)数据库,必须先丢弃这个实例,并创建一个新的实例。
重申一遍:
􀂉 实例是一组后台进程和共享内存。
􀂉 数据库是磁盘上存储的数据集合。
􀂉 实例“一生”只能装载并打开一个数据库。
􀂉 数据库可以由一个或多个实例(使用RAC)装载和打开。

如果有人谈到实例,他指的就是Oracle的进程和内存。提到数据库时,则是说保存数据的物理文件。可以从多个实例访问一个数据库,但是一个实例一次只能访问一个数据库。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/110321/viewspace-609298/,如需转载,请注明出处,否则将追究法律责任。

上一篇: 今天没心情,pass
请登录后发表评论 登录
全部评论

注册时间:2009-06-26

  • 博文量
    167
  • 访问量
    291933