Oracle每次启动(startup nomount)时,都会从pfile或spile中读取配置参数。
pfile是文本文件,类似于PG的postgresql.conf,spfile是pfile的二进制形式,它们是互相替代的。可以从pfile创建spfile,也可以从spfile创建pfile:
create spfile from pfile;
create pfile from spfile;
启动时,在$ORACLE_HOME/dbs目录下寻找spfile或pfile读取参数,优先级顺序为:
spfileSID.ora
spfile.ora
initSID.ora
init.ora
spfile优先。
手工建库时,需要创建第一个参数文件,命名为init<实例名>.ora,就是pfile。
启动后,修改参数时,可以指定scope=spfile|memory|both,如果没有scope默认是both。
如果不用spfile,只用pfile,运行时修改参数,不存到pfile,只存内存(即只有scope=memory选项),重启仍然按照pfile中的参数值启动,这点类似于PG的postgresq.conf。
如果使用spfile,运行时修改参数,可以存到spfile,内存或兼有(即scope=spfile|memory|both),如果存到spfile,重启就按照spfile的参数启动。
无论使用spfile或pfile,修改参数后是否立即生效,取决于参数类型,与scope无关。
RMAN不能备份pfile,可备份spfile。
spfile的好处是,1)alter system set parameter可保存到spfile中,但不能保存到pfile中。2)Oracle自动优化参数时使用spfile。
从另一个维度分类参数:有statics和dynamic两种,dynamic设置后立即生效,static重启实例后生效。dynamic参数scope可选3种,static参数scope只能选spfile。
在运行的实例中修改参数,例如:
alter system set db_recovery_file_dest_size = 10G scope=spfile;
show parameter db_recovery_file_dest_size;