使用alter system set修改参数不生效
最近在用虚拟机上的Oracle RAC做实验,看到后台日志一直报错,原因是配置的log_archive_dest_2参数指到了节点2,而节点2又没有开机,所以导致一直有报错。于是想这一参数是之前做实验的时候修改的,现在不需要了,直接把这个参数重置一下就可以了,于是执行了下面的语句: altersystemresetlog_archive_dest_2; 再使用show parameter查看参数已经被清空了: SQL>showparameterlog_archive_dest_2 NAME TYPE VALUE ----------------------------------------------------------------------------- log_archive_dest_2 string 看alert日志中报错也没有了,以为这样事情就结束了。但事实上还没有结束。等下一次数据库重启后看到之前的报错又出现了,而且log_archive_dest_2参数的设置又恢复到了重置之前的值: SQL>showparameterlog_archive_dest_2 NAME TYPE VALUE ----------------------------------------------------------------------------- log_archive_dest_2 string service=rac2 难道是上次重置没有成功吗? 从上次的检查结果来看重置是成功的,而且alert日志中也提示修改成功。 那为什么这么灵异的事情居然发生了呢? 尝试再次重置: SQL>altersystemresetlog_archive_dest_2; altersystemresetlog_archive_dest_2 * ERRORatline1: ORA-32010:cannotfindentrytodeleteinSPFILE 看到出现上面的报错,是说spfile中没有相应的条目可以删除。 如果没有条目我的设置又是从哪里来的呢? 于是生成pfile来查看参数文件中关于log_archive_dest_2具体是怎么设置的: orcl2.log_archive_dest_1='location=/home/oracle/rac2' orcl1.log_archive_dest_1='location=/home/oracle/rac1' *.log_archive_dest_1='location=+data' orcl2.log_archive_dest_2='service=rac1' orcl1.log_archive_dest_2='service=rac2' 从上面可以看到针对每一个实例的log_archive_dest_2都做了设置,难道是这个原因么? 再次尝试重置,这次语句如下: altersystemresetlog_archive_dest_2sid='orcl1'; 再次生成pfile文件,看到orcl1.log_archive_dest_2='service=rac2'这条记录已经没有了,说明已经把配置清除了,重启实例再次查看: SQL>showparameterlog_archive_dest_2 NAME TYPE VALUE ----------------------------------------------------------------------------- log_archive_dest_2 string alert日志中也不再报错了。 那么问题又来了,我第一次清除的又是什么配置呢? 有经验的同学应该已经想到这个问题的原因了。我们继续看下面的分析。 我们再回到第一次生成的spfile文件中可以看到如下配置,我们以log_archive_dest_1参数为例 orcl2.log_archive_dest_1='location=/home/oracle/rac2' orcl1.log_archive_dest_1='location=/home/oracle/rac1' *.log_archive_dest_1='location=+data' 对于log_archive_dest_1参数设置有两类,一类是'*.'开头的,一个是以'<sid>.'开头的。'*.'开头的设置是对所有与数据库相关的且没有设置该参数的实例有效,而以'<sid>.'开头的设置只对设置对应的实例有效。 我这前是对两个实例orcl1和orcl2的log_archive_dest_1分别设置了不同的值,而分别设置之前所有的实例的log_archive_dest_1参数值都是'location=+data'。 我们再来看alter system set|reset parameter的语法: set parameter parameter_name= parameter_value[,parameter_value]... [COMMENT=string] [DEFERRED] [{SCOPE={MEMORY|SPFILE|BOTH} |SID={'sid'|'*'} }... ] reset parameter parameter_name [{SCOPE=SPFILE |SID={'sid'|'*'} }... ] 从上面的语法可以看到,设置和重置参数都有一个可选项:SID = { 'sid' | '*' },而默认的都是SID='*'。 这里应该就可以解释我第一次重置log_archive_dest_2时为什么可以成功,而第二次没有成功的原因:我第一次删除了*.log_archive_dest_2='xxxx'这一条目,第一次再次删除时文件中没有了,所以报错。 这也能解释为什么重置时加上sid='orcl1'项后重启依然生效。 还有一个问题就是如果参数文件中,对于同一个参数同时有'*.'开头的和以'<sid>.'开头的参数设置时,Oracle会选哪个做为实例的参数设置的,我们来看一句官方文档中对SID的描述,就可以回答这个问题了: SIDThe
If you do not specify this clause,then:
小提示:可以使用show spparameter <parameter_name>查看spfile中对于参数的设置 sys@ORA11G>showspparameterlog_archive_dest_1 SID NAME TYPE VALUE ---------------------------------------------------------------------------- ora11g log_archive_dest_1 string location=/home/oracle/dump * log_archive_dest_1 string location=/u01/ 参考:http://docs.oracle.com/cd/E11882_01/server.112/e41084/statements_2014.htm#i2061284 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |