Oracle 参数和pfile、spfile
  TEZNKK3IfmPf 2024年03月29日 50 0

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;

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2024年03月29日 0

暂无评论

推荐阅读
  TEZNKK3IfmPf   2024年03月29日   51   0   0 Oracle
  TEZNKK3IfmPf   2024年03月22日   56   0   0 数据库Oracle
  TEZNKK3IfmPf   2024年03月22日   42   0   0 Oracle
  TEZNKK3IfmPf   2024年04月19日   33   0   0 Oracle
  TEZNKK3IfmPf   2024年03月22日   107   0   0 数据库Oracle
TEZNKK3IfmPf