一、Oracle的参数文件
在Oracle数据库中,参数文件在通常情况下指的就是初始化参数文件(Initialization Parameter File)。在参数文件中包括了初始化参数文件和服务器端参数文件。在Oracle数据库启动的时候就会读取参数文件,然后根据参数文件中的参数值来分配内存和启动一系列的后台进程。
视频讲解如下:
Oracle的参数文件 |
---|
【赵渝强老师】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。
视频讲解如下:
Oracle的告警日志文件 |
---|
【赵渝强老师】Oracle的告警日志文件 |
警报文件的位置可以通过查询数据字典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