Oracle参数设置之set和reset怎么用
这篇文章主要为大家展示了“Oracle参数设置之set和reset怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Oracle参数设置之set和reset怎么用”这篇文章吧。
环境:Oracle 10.2.0.5 RAC
需求:节点1的aq_tm_processes要求恢复默认,节点2设置要求保持不变
背景介绍:
从10.2官档可以查到aq_tm_processes参数,看到该参数的默认值是0,我们姑且叫做它为默认0.
然后,在实际上发现,这个默认0和我们手工将其SET设置成0,效果是完全不一样的。
与同事交流此事,最终得知一个技术细节:
Oracle中,使用SET设置参数值实际上是少做很多事情的,如果你想恢复Oracle的默认值,最有效的办法就是RESET该值,这样,才会一切都按照Oracle默认的设计。
具体来看现在的场景,如果你对参数aq_tm_processes设置为0.那和本来的默认0是完全不一样的。
如果是设置0,所有q00小工进程都会关闭不会再启动。如果是默认0,q00小工进程是可以启动的。
1.构建测试环境
目前生产的参数内容是类似这样,有全局设置,有实例1的设置,如下:
*.aq_tm_processes=1jy1.aq_tm_processes=0
我们知道,针对实例的设置优先级是高的,也就是说这样设置的效果就是实例1该参数是0,实例2该参数是1.
即:实例1无法启动q00小工进程,实例2可以启动q00小工进程。
构建测试环境模拟生产:
先设置aq_tm_processes为1:
altersystemsetaq_tm_processes=1scope=bothsid='*';--createpfile='/tmp/pfile11.ora'fromspfile;
此时参数文件中就会有这样的设置:
*.aq_tm_processes=1
再设置实例1的aq_tm_processes为0
altersystemsetaq_tm_processes=0scope=bothsid='jy1';--createpfile='/tmp/pfile12.ora'fromspfile;
此时参数文件中就会有这样的设置:
*.aq_tm_processes=1jy1.aq_tm_processes=0
此时就模拟了生产环境的现状。下面来看下实际的操作过程:
SQL>SQL>altersystemsetaq_tm_processes=1scope=bothsid='*';Systemaltered.SQL>createpfile='/tmp/pfile11.ora'fromspfile;Filecreated.SQL>showparameteraqNAMETYPEVALUE-----------------------------------------------------------------------------aq_tm_processesinteger1SQL>!ps-ef|grepq00oracle146227385015:27pts/100:00:00/bin/bash-cps-ef|grepq00oracle14641462015:27pts/100:00:00grepq00oracle265341015:08?00:00:00ora_q002_jy1oracle315381015:21?00:00:00ora_q000_jy1SQL>SQL>altersystemsetaq_tm_processes=0scope=bothsid='jy1';Systemaltered.SQL>createpfile='/tmp/pfile12.ora'fromspfile;Filecreated.SQL>showparameteraqNAMETYPEVALUE-----------------------------------------------------------------------------aq_tm_processesinteger0SQL>!ps-ef|grepq00oracle204427385015:28pts/100:00:00/bin/bash-cps-ef|grepq00oracle20462044015:28pts/100:00:00grepq00SQL>
可以看到,确实设置为0之后q00进程就消失了,即使再重启实例也是一样的,q00进程不再会启动。
2.测试方案
现在我们要做的就是保障不更改节点2的设置情况下,将节点1的aq_tm_processes恢复默认。
2.1 尝试直接reset参数指定节点1,然后重启验证?
altersystemresetaq_tm_processesscope=spfilesid='jy1';createpfile='/tmp/pfile13.ora'fromspfile;
重启节点1验证?确认是否可以实现需求?
具体实际操作如下:
SQL>altersystemresetaq_tm_processesscope=spfilesid='jy1';Systemaltered.SQL>createpfile='/tmp/pfile13.ora'fromspfile;Filecreated.SQL>showparameteraqNAMETYPEVALUE-----------------------------------------------------------------------------aq_tm_processesinteger0SQL>!ps-ef|grepq00oracle380127385015:32pts/100:00:00/bin/bash-cps-ef|grepq00oracle38033801015:32pts/100:00:00grepq00SQL>startupforceORACLEinstancestarted.TotalSystemGlobalArea599785472bytesFixedSize2098112bytesVariableSize301993024bytesDatabaseBuffers289406976bytesRedoBuffers6287360bytesDatabasemounted.Databaseopened.SQL>showparameteraqNAMETYPEVALUE-----------------------------------------------------------------------------aq_tm_processesinteger1SQL>!ps-ef|grepq00oracle42281015:33?00:00:00ora_q000_jy1oracle42321015:33?00:00:00ora_q002_jy1oracle502127385015:35pts/100:00:00/bin/bash-cps-ef|grepq00oracle50235021015:35pts/100:00:00grepq00SQL>
可以看到,答案明显是:不可以。
因为这样只会将实例1的参数reset,但是由于之前还有全局参数*,所以重启实例1后会发现,aq_tm_processes参数会是1。
也就是说,针对实例1的设置去掉了,自然会沿袭整体的设置。
2.2 实验正确的方式
有了上面的基础,就有了实现需求的思路:
我们想下,如果把全局参数也reset,会影响到节点2之前的设置,那么这样,只能将节点2的值单独设定,然后再reset全局参数。
altersystemsetaq_tm_processes=1scope=bothsid='jy2';--createpfile='/tmp/pfile14.ora'fromspfile;altersystemresetaq_tm_processesscope=spfilesid='*';--createpfile='/tmp/pfile15.ora'fromspfile;重启节点1验证??确认是否可以实现需求?具体实际操作如下:SQL>altersystemsetaq_tm_processes=1scope=bothsid='jy2';Systemaltered.SQL>createpfile='/tmp/pfile14.ora'fromspfile;Filecreated.SQL>altersystemresetaq_tm_processesscope=spfilesid='*';Systemaltered.SQL>createpfile='/tmp/pfile15.ora'fromspfile;Filecreated.SQL>startupforceORACLEinstancestarted.TotalSystemGlobalArea599785472bytesFixedSize2098112bytesVariableSize301993024bytesDatabaseBuffers289406976bytesRedoBuffers6287360bytesDatabasemounted.Databaseopened.SQL>showparameteraqNAMETYPEVALUE-----------------------------------------------------------------------------aq_tm_processesinteger0SQL>!ps-ef|grepq00oracle74461115:40?00:00:00ora_q000_jy1oracle74481015:40?00:00:00ora_q001_jy1oracle74501015:40?00:00:00ora_q002_jy1oracle74521015:40?00:00:00ora_q003_jy1oracle748027385015:41pts/100:00:00/bin/bash-cps-ef|grepq00oracle74827480015:41pts/100:00:00grepq00SQL>
可以看到,真实操作测试验证的答案和预想的一致:可以。
注:所有创建pfile的步骤都可以去掉。当时是因为想确认理论是否正确才给每一步后加了这个操作。
3.总结
那么总结归纳下,实际在客户环境下,就是应该做以下三个步骤完成需求:
--保障节点2的设置不变altersystemsetaq_tm_processes=1scope=spfilesid='jy2';--reset节点1的设置altersystemresetaq_tm_processesscope=spfilesid='jy1';--reset全局的设置altersystemresetaq_tm_processesscope=spfilesid='*';
本文知识点总结:其实只需下面这3个知识点清楚就ok了:
reset操作实际只是将这个值从spfile中移除;
针对某个实例级别的设置优先级高于整体设置;
注意Oracle对于SET参数值这种方式,实际上少做了很多事情,简单理解就是默认0和设置0不一样。
以上是“Oracle参数设置之set和reset怎么用”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。