2.3 物理存储结构

逻辑存储结构是为了管理Oracle数据而定义的具有逻辑层次关系的抽象概念,不容易理解;但物理存储结构比较具体和直观,它用来描述Oracle数据在磁盘上的物理组成情况。从大的角度来讲,Oracle的数据在逻辑上存储在表空间中,而在物理上存储在表空间包含的物理文件(即数据文件)中。

Oracle数据库的物理存储结构由多种物理文件组成,主要有数据文件、控制文件、重做日志文件、归档日志文件、参数文件、密码文件和警告日志文件等,如图2.5所示。下面将对这些物理文件进行讲解。

图2.5 Oracle的物理存储结构

2.3.1 数据文件

数据文件是用于保存用户应用程序数据和Oracle系统内部数据的文件,它们在操作系统中就是普通的文件,Oracle在创建表空间的同时会创建数据文件。Oracle数据库在逻辑上由表空间组成,每个表空间可以包含一个或多个数据文件,一个数据文件只能隶属于一个表空间,如图2.5所示。

在创建表空间的同时,Oracle会创建该表空间的数据文件。在表空间中创建数据对象(如表、索引、簇等)时,用户是无法指定使用哪一个数据文件来进行存储的,只能由Oracle系统负责为数据对象选择具体的数据文件,并在其中分配物理存储空间。一个数据对象的数据可以全部存储在一个数据文件中,也可以分布存储在同一个表空间的多个数据文件中。

在读取数据时,Oracle系统首先从数据文件中读取数据,并将数据存储在内存的高速数据缓冲区中。如果用户要读取数据库中的某些数据,而请求的数据又不在内存的高速数据缓冲区中,则需要从相应的数据文件中读取数据并存储在缓冲区中。当修改和插入数据时,Oracle不会立即将数据写入数据文件中,而是把这些数据保存在数据缓冲区中,然后由Oracle的后台进程DBWR决定如何将其写入相应的数据文件中。这样的存储方式减少了磁盘的I/O操作,提高了系统的相应性能。

【例2.4】查询dba_data_files或v$datafile数据字典,了解Oracle系统的数据文件信息,具体代码如下。(实例位置:资源包\TM\sl\2\2)

     SQL> col file_name for a50;
     SQL> set linesize 100;
     SQL> select file_name,tablespace_name from dba_data_files;

本例运行结果如图2.6所示。

从图2.6中可以看到3种类型的数据文件,即系统数据文件(SYSTEM01.DBF和SYSAUX01.DBF)、撤销数据文件(UNDOTBS01.DBF)和用户数据文件(USERS01.DBF、EXAMPLE01.DBF),下面对这3种类型的数据文件进行介绍。

(1)系统数据文件用于存储“特殊”的用户数据和Oracle系统本身的数据。用户建立的表名、列名及字段类型等,这些属于用户数据范畴,存储在系统表空间所包含的数据文件中。Oracle系统内部的数据字典、系统表(如dba_data_files、dba_temp_files等)中所存储的数据属于Oracle系统的内部数据,也存储在系统表空间所包含的数据文件中。

(2)撤销数据文件隶属于撤销表空间。如果修改Oracle数据库中的数据,那么就必须使用撤销段,撤销段用来临时存储修改前的旧数据,通常存储在一个单独的撤销表空间中,这个撤销表空间所包含的数据文件就是撤销数据文件。

(3)用户数据文件用于存储用户应用系统的数据,这些数据包括与应用系统有关的所有相关信息。例如,上述USERS01.DBF和EXAMPLE01.DBF文件就是一个具体应用系统的两个数据文件。

在上述代码中并没有看到临时表空间所包含的数据文件,这是由于临时数据文件本身的特殊性。从Oracle 9i以后,Oracle将临时表空间所对应的临时数据文件与一般数据文件分开了。要了解Oracle系统的临时数据文件信息,可以从dba_temp_files或v$tempfile数据字典中查询。

【例2.5】查询dba_temp_files或v$tempfile数据字典,查看临时文件的信息,具体代码如下。(实例位置:资源包\TM\sl\2\3)

     SQL> col file_name format a50;
     SQL> col tablespace_name format a20;
     SQL> select file_name,tablespace_name from dba_temp_files;

本例运行结果如图2.7所示。

图2.6 Oracle系统的数据文件信息

图2.7 查看临时文件的信息

2.3.2 控制文件

控制文件是一个二进制文件,它记录了数据库的物理结构,其中主要包含数据库名、数据文件与日志文件的名字和位置、数据库建立日期等信息。控制文件一般在安装Oracle系统时或创建数据库时自动创建,控制文件所存储的路径由服务器参数文件SPFILEORCL.ORA的CONTROL_ FILES参数值来指定。

由于控制文件存储了数据文件、日志文件等相关信息,因此Oracle实例在启动时必须访问控制文件。如果控制文件正常,实例才能加载并打开数据库;但如果控制文件中记录了错误的信息,或者实例无法找到一个可用的控制文件,则实例将无法正常启动。

当Oracle实例正常启动时,系统首先要访问的是初始化参数文件SPFILE;然后Oracle为系统全局区(SGA)分配内存,这时Oracle实例处于安装状态,并且控制文件处于打开状态;接下来Oracle会自动读出控制文件中的所有数据文件和日志文件的信息,并打开当前数据库中所有的数据文件和所有的日志文件以供用户访问。

每个数据库至少拥有一个控制文件,一个数据库可以同时拥有多个控制文件,但是一个控制文件只能属于一个数据库。控制文件内部除了存储数据库名及其创建日期、数据文件、日志文件等相关信息,在系统运行过程中,还存储了系统更改号、检查点信息及归档的当前状态等信息。

Oracle数据库系统出于安全考虑,在安装Oracle数据库或创建数据库时,系统会自动创建两个或三个控制文件,每个控制文件记录相同的信息。这样可确保在数据库运行时,如果某个控制文件损坏,则Oracle将会自动使用另一个控制文件;如果所有控制文件都损坏,则系统将无法工作。

【例2.6】查询v$controlfile数据字典,查看Oracle系统的控制文件信息,具体代码如下。(实例位置:资源包\TM\sl\2\4)

     SQL> col name format a60;
     SQL> select name from v$controlfile;

本例运行结果如图2.8所示。

图2.8 Oracle系统的控制文件信息

说明

当数据库的物理组成更改时,Oracle将自动更改该数据库的控制文件;当数据库中的数据需要恢复时,Oracle也要使用控制文件。

2.3.3 日志文件

日志文件的主要功能是记录对数据所做的修改,对数据库所做的修改几乎都记录在日志文件中。在出现问题时,可以通过日志文件得到原始数据,从而保证不丢失已有操作成果。Oracle的日志文件包括重做日志文件(redo log file)和归档日志文件(archive log file),它们是Oracle系统的主要文件,尤其是重做日志文件,它是Oracle数据库系统正常运行所不可或缺的。下面将介绍这两种日志文件。

1.重做日志文件

重做日志文件用来记录数据库所有发生过的更改信息(修改、添加、删除等)以及由Oracle内部行为(创建数据表、索引等)而引起的数据库变化信息。在数据库恢复时,可以从该日志文件中读取原始记录。在数据库运行期间,当用户执行COMMIT命令(数据库提交命令)时,数据库首先将每笔操作的原始记录写入日志文件中,只有在写入日志文件成功后才把新的记录传递给应用程序,所以在日志文件上可以随时读取原始记录以恢复某些数据。

技巧

对表或者整个表空间设定NOLOGGING属性,可使基于表或表空间中的DML操作(如创建表、删除视图、修改索引等)不生成日志信息,从而减少日志信息。

为了保障数据库系统的安全性,每个Oracle实例都启用一个日志线程来记录数据库的变化。日志线程由若干“日志组”构成,而每个日志组又由一个或者多个日志文件构成。

【例2.7】查询v$logfile视图了解Oracle系统的日志文件信息,代码如下。(实例位置:资源包\TM\sl\2\5)

     SQL> col member for a50
     SQL> select member from v$logfile;

本例运行结果如图2.9所示。

Oracle系统在运行过程中产生的日志信息,首先被临时存储在系统全局区(SGA)的重做日志缓冲区中,当用户发出COMMIT命令(或日志缓冲区信息满1/3)时,日志写入(LGWR)进程将日志信息从重做日志缓冲区中读出,然后将其写入日志文件组中序列号较小的文件里,在一个日志组被写满后接着写入另一个日志组中。在LGWR进程将所有能用的日志文件都使用过一遍之后,它将再次转向第一个日志组重新覆写。

图2.9 Oracle系统的日志文件信息

2.归档日志文件

在所有的日志文件被写入一遍之后,LGWR进程将再次转向第一个日志组进行重新覆写,这样势必会导致一部分较早的日志信息被覆盖,但Oracle通过归档日志文件解决了这个问题。

Oracle数据库可以运行在两种模式下,即归档模式和非归档模式。非归档模式是指在系统运行期间,所产生的日志信息不断地记录到日志文件组中,当所有重做日志组被写满后,又重新从第一个日志组开始覆写;归档模式就是在各个日志文件都被写满而即将被覆盖之前,先由归档(ARCH)进程将即将被覆盖的日志文件中的日志信息读出,然后将其写入归档日志文件中,而这个过程又被称为归档操作。

在归档操作进行的过程中,LGWR进程需要等待ARCH进程结束才能开始覆写日志文件,这样就延迟了系统的响应时间,而且归档日志文件本身又会占用大量的磁盘空间,这些都会影响系统的整体性能。所以在默认情况下,Oracle系统不采用归档模式运行。

【例2.8】通过v$database视图查看当前Oracle系统是否采用归档模式,代码如下。(实例位置:资源包\TM\sl\2\6)

     SQL> col name format a30;
     SQL> select dbid,name,log_mode from v$database;

本例运行结果如图2.10所示。

如果将Oracle数据库系统设置成在归档模式下运行,则可以通过服务器参数文件SPFILE的log_archive_dest参数来确定归档日志文件的所在路径。

【例2.9】查询归档日志文件的所在路径,代码如下。(实例位置:资源包\TM\sl\2\7)

     SQL> set pagesize 30;
     SQL> show parameter log_archive_dest;

本例运行结果如图2.11所示。

图2.10 查看当前Oracle系统是否采用归档模式

图2.11 归档日志文件的所在路径

技巧

若要显示SPFILE的指定参数信息,只需要使用show parameter+参数名即可。

2.3.4 服务器参数文件

服务器参数文件(server parameter file,SPFILE,即参数文件)是二进制文件,用来记录Oracle数据库的基本参数信息(如数据库名、控制文件所在路径、日志缓冲大小等)。数据库实例在启动之前,Oracle系统首先会读取SPFILE中设置的这些参数,然后根据这些初始化参数来配置和启动实例。例如,设置标准数据块的大小(即参数db_block_size的值)、设置日志缓冲区的大小(即参数log_buffer的值)等,所以SPFILE非常重要。SPFILE在安装Oracle数据库系统时由系统自动创建,文件的名称为SPFILEsid.ora,其中sid为所创建的数据库实例名。

与早期版本的初始化参数文件INITsid.ora不同的是,SPFILE中的参数由Oracle系统自动维护。如果要对某些参数进行修改,尽可能不直接对SPFILE进行编辑,最好通过Oracle企业管理器(OEM)或alter system命令来修改,所修改过的参数会自动写到SPFILE中。

1.查看服务器参数

用户可以通过如下两种方式查看数据库的服务器参数。

(1)可通过查询视图v$parameter确定参数的默认值是否被修改过,以及是否可以用alter system和alter session命令修改。

【例2.10】查询视图v$parameter中name、value、ismodified列的值,代码如下。(实例位置:资源包\TM\sl\2\8)

     SQL> col name for a30;
     SQL> col value for a30;
     SQL> select name,value,ismodified from v$parameter;

本例运行结果如图2.12所示。

(2)可以使用SQL*Plus的show parameter命令显示服务器的参数。

【例2.11】通过show parameter命令显示服务器参数,代码如下。

     SQL> show parameter

本例运行结果如图2.13所示。

图2.12 查询视图v$parameter

图2.13 显示服务器参数

2.修改服务器参数

修改数据库的服务器参数,主要通过OEM或ALTER SYSTEM命令来实现。

(1)通过OEM修改。首先需要使用system用户登录OEM;然后选择“服务器”页面中的“初始化参数”选项,将打开如图2.14所示的“初始化参数”页面,在该页面的“值”列中就可以修改参数值,最后保存它。

图2.14 OEM中的初始化参数

(2)使用ALTER SYSTEM命令修改服务器参数。

【例2.12】通过ALTER SYSTEM命令修改标准数据块的大小为4096 B,代码及运行结果如下。

     alter system set db_block_size=4096;
     系统已更改。

2.3.5 密码文件、警告文件和跟踪文件

Oracle系统运行时,除了必要的数据文件、控制文件、日志文件及服务器参数文件,还需要一些辅助文件,如密码文件、警告文件和跟踪文件,下面对这些辅助文件进行简单的介绍。

1.密码文件

密码文件是Oracle系统用于验证sysdba权限的二进制文件,当远程用户以sysdba或sysoper连接到数据库时,一般要用密码文件验证。

Oracle(这里以发行版2为例)密码文件的默认存储位置在%dbhome_1%\database目录下,命名格式为PWD<sid>,其中sid表示数据库实例名。密码文件既可以在创建数据库实例时自动创建,也可以使用ORAPWD.mp4工具手动创建。创建密码文件的命令格式如下。

     C:\>ORAPWD FILE=<filename> PASSWORD=<password> ENTRIES=<max_users>

 filename:表示密码文件名称。

 password:表示设置internal/sys账户口令。

 max_users:表示密码文件中可以存储的最大用户数,对应允许以sysdba/sysoper权限登录数据库的最大用户数。

创建了密码文件后,需要设置初始化参数remote_login_passwordfile来控制密码文件的使用状态,通常有以下3种状态值:NONE表示只要通过操作系统验证,就不用通过Oracle密码文件验证;SHARED表示多个数据库实例都可以采用此密码文件验证;EXCLUSIVE表示只有一个数据库实例可以使用此密码文件验证。

【例2.13】创建一个密码文件,其sys口令为012345,代码如下。

     C:\>ORAPWD FILE=E:\app\Admin\product\11.2.0\dbhome_1\database\PWDorcl.ora password=012345 entries =40
2.警告文件

警告文件(即警告日志文件)是一个存储在Oracle系统目录下的文本文件(名称通常为alert_orcl.log),它用来记录Oracle系统的运行信息和错误信息。运行信息一般包括Oracle实例的启动与关闭、建立表空间、增加数据文件等;错误信息包括空间扩展失败、启动实例失败等。

当Oracle系统安装完毕后,其实例日常运行的基本信息都会记录在警告文件中。警告文件的路径可通过Oracle系统的BACKGROUND_DUMP_DEST参数值来查看,并且该参数值由服务器进程和后台进程写入。

【例2.14】在v$parameter视图中查看当前实例的警告文件的路径,代码及其运行结果如下。

     SQL> col name for a20;
     SQL> col value for a50;
     SQL> select name, value from v$parameter where name = 'background_dump_dest';
     NAME                    VALUE
     ------------           ------------------------------------------------
     background_dump_dest    e:\app\administrator\diag\rdbms\orcl\orcl\trace

注意

随着时间的推移,警告文件会越来越大,数据库管理员应该定期删除警告文件。

3.跟踪文件

跟踪文件包括后台进程跟踪文件和用户进程跟踪文件。后台进程跟踪文件用于记录后台进程的警告或错误消息。后台进程跟踪文件的磁盘位置由初始化参数BACKGROUND_DUMP_DEST确定,后台进程跟踪文件的命名格式为<sid>_<processname>_<spid>.trc,如orcl_cjq0_5172.trc。用户进程跟踪文件用于记载与用户进程相关的信息,它主要用于跟踪SQL语句。通过用户进程跟踪文件,可以判断SQL语句的执行性能。用户进程跟踪文件的位置由初始化参数USER_DUMP_DEST确定,用户进程跟踪文件的命名格式为<sid>_ora_<spid>.trc,如orcl_ora_4888.trc。

除了.trc文件,还有.trm文件。.trm文件为跟踪元数据文件,伴随着.trc文件产生,一个.trm对应一个.trc文件,.trm文件包含.trc文件的结构化信息。

【例2.15】在v$parameter视图中查看当前实例用户跟踪文件的路径,代码及其运行结果如下。

     SQL> select value from v$parameter where name = 'user_dump_dest';
     VALUE
     --------------------------------------------------
     e:\app\administrator\diag\rdbms\orcl\orcl\trace

说明

每个后台进程都有对应的后台进程跟踪文件。