一、Oracle的参数文件
在Oracle数据库中,参数文件在通常情况下指的就是初始化参数文件(Initialization Parameter File)。在参数文件中包括了初始化参数文件和服务器端参数文件。在Oracle数据库启动的时候就会读取参数文件,然后根据参数文件中的参数值来分配内存和启动一系列的后台进程。
视频讲解如下:
Oracle的参数文件有两种不同的类型。在Oracle 9i版本之前,Oracle采用的PFile类型的参数文件,该文件是一个文本类型的文件;而从Oracle 9i版本之后,采用了SPFile类型的参数文件,该文件是一个二进制类型的文件。可以通过执行下面的语句查看当前的参数文件信息。
SQL> show parameter pfile # 输出的信息如下: NAME TYPE VALUE ------------ ------- -------------------------------- spfile string /u01/app/oracle/dbs/spfileorcl.ora
下面的语句将SPFile类型的参数文件转换成了PFile类型的参数文件。
SQL> create pfile='/home/oracle/pfile.ora' from spfile;
查看文件/home/oracle/pfile.ora的内容如下:
orcl.__data_transfer_cache_size=0 orcl.__db_cache_size=553648128 orcl.__inmemory_ext_roarea=0 orcl.__inmemory_ext_rwarea=0 orcl.__java_pool_size=16777216 orcl.__large_pool_size=16777216 orcl.__oracle_base='/u01/app/oracle'#ORACLE_BASE set from environment orcl.__pga_aggregate_target=671088640 orcl.__sga_target=989855744 orcl.__shared_io_pool_size=50331648 orcl.__shared_pool_size=335544320 orcl.__streams_pool_size=0 orcl.__unified_pga_pool_size=0 *.audit_file_dest='/u01/app/oracle/admin/orcl/adump' *.audit_trail='db' *.compatible='21.0.0' *.control_files='/u01/app/oracle/oradata/ORCL/control01.ctl','/u01/app/oracle/fast_recovery_area/ORCL/control02.ctl' *.db_block_size=8192 *.db_name='orcl' *.db_recovery_file_dest='/u01/app/oracle/fast_recovery_area' *.db_recovery_file_dest_size=11511m *.diagnostic_dest='/u01/app/oracle' *.dispatchers='(PROTOCOL=TCP) (SERVICE=orclXDB)' *.enable_pluggable_database=true *.local_listener='LISTENER_ORCL' *.memory_target=1572m *.nls_language='AMERICAN' *.nls_territory='AMERICA' *.open_cursors=300 *.processes=300 *.remote_login_passwordfile='EXCLUSIVE' *.undo_tablespace='UNDOTBS1'
注意:从PFile的文件内容中可以看出,参数文件中记录了控制文件的位置。而控制文件又记录的数据文件和联机重做日志的位置。通过这样的关系在启动数据库的时候,Oracle就可以找到所有需要的文件了。
二、Oracle的告警日志文件
Oracle的告警日志文件按照时间的先后顺序,记录了数据库的重大活动和所发生的错误信息以及警告信息。因此,当Oracle数据库出现任何问题的时候,首先就应当检查告警日志文件。警报文件的名字的格式是alert_SID.log。
视频讲解如下:
警报文件的位置可以通过查询数据字典v$diag_info得到,例如:
SQL> select name,value from v$diag_info;
输出的信息如下图所示:
在参数Diag Trace所对应的目录/u01/app/oracle/diag/rdbms/orcl/orcl/trace下就可以找到当前数据库所对应的告警日志文件。例如:
[oracle@oraclevm trace]$ pwd /u01/app/oracle/diag/rdbms/orcl/orcl/trace [oracle@oraclevm trace]$ ll alert_orcl.log -rw-r-----. 1 oracle oinstall 113659 Mar 19 21:16 alert_orcl.log [oracle@oraclevm trace]$
下面展示了告警日志文件中记录的部分信息。可以看出在告警日志文件中记录了数据库的启动和停止信息。
...... Starting background process PMON 2021-12-06T10:20:36.785883+08:00 PMON started with pid=2, OS id=67342 Starting background process CLMN 2021-12-06T10:20:36.806788+08:00 CLMN started with pid=3, OS id=67346 Starting background process PSP0 2021-12-06T10:20:36.826823+08:00 PSP0 started with pid=4, OS id=67350 Starting background process VKTM ...... Shutdown is initiated by sqlplus@oraclevm (TNS V1-V3). Stopping background process SMCO Shutting down instance: further logons disabled Stopping background process MMNL Stopping background process MMON ......
注意:告警日志文件中还记录了数据库的结构变化、强制审计的信息和死锁的信息。例如,之前在users表空间中添加的user02数据文件也被记录到了告警日志文件中。记录的信息如下:
2022-03-19T21:16:25.760425+08:00 alter tablespace users add datafile '/u01/app/oracle/oradata/ORCL/users02.dbf' size 10M Completed: alter tablespace users add datafile '/u01/app/oracle/oradata/ORCL/users02.dbf' size 10M