Oracle參數(shù)設(shè)置教程之set和reset的實(shí)用案例
前言
本文主要給大家介紹了關(guān)于Oracle參數(shù)設(shè)置之set和reset的相關(guān)內(nèi)容,分享出來(lái)供大家參考學(xué)習(xí),下面話不多說(shuō)了,來(lái)一起看看詳細(xì)的介紹吧。
環(huán)境:Oracle 10.2.0.5 RAC
需求:節(jié)點(diǎn)1的aq_tm_processes要求恢復(fù)默認(rèn),節(jié)點(diǎn)2設(shè)置要求保持不變
背景介紹:
從10.2官檔可以查到aq_tm_processes參數(shù),看到該參數(shù)的默認(rèn)值是0,我們姑且叫做它為默認(rèn)0.
然后,在實(shí)際上發(fā)現(xiàn),這個(gè)默認(rèn)0和我們手工將其SET設(shè)置成0,效果是完全不一樣的。
與同事交流此事,最終得知一個(gè)技術(shù)細(xì)節(jié):
Oracle中,使用SET設(shè)置參數(shù)值實(shí)際上是少做很多事情的,如果你想恢復(fù)Oracle的默認(rèn)值,最有效的辦法就是RESET該值,這樣,才會(huì)一切都按照Oracle默認(rèn)的設(shè)計(jì)。
具體來(lái)看現(xiàn)在的場(chǎng)景,如果你對(duì)參數(shù)aq_tm_processes設(shè)置為0.那和本來(lái)的默認(rèn)0是完全不一樣的。
如果是設(shè)置0,所有q00小工進(jìn)程都會(huì)關(guān)閉不會(huì)再啟動(dòng)。如果是默認(rèn)0,q00小工進(jìn)程是可以啟動(dòng)的。
1.構(gòu)建測(cè)試環(huán)境
目前生產(chǎn)的參數(shù)內(nèi)容是類(lèi)似這樣,有全局設(shè)置,有實(shí)例1的設(shè)置,如下:
*.aq_tm_processes=1 jy1.aq_tm_processes=0
我們知道,針對(duì)實(shí)例的設(shè)置優(yōu)先級(jí)是高的,也就是說(shuō)這樣設(shè)置的效果就是實(shí)例1該參數(shù)是0,實(shí)例2該參數(shù)是1.
即:實(shí)例1無(wú)法啟動(dòng)q00小工進(jìn)程,實(shí)例2可以啟動(dòng)q00小工進(jìn)程。
構(gòu)建測(cè)試環(huán)境模擬生產(chǎn):
先設(shè)置aq_tm_processes為1:
alter system set aq_tm_processes = 1 scope=both sid='*'; --create pfile='/tmp/pfile11.ora' from spfile;
此時(shí)參數(shù)文件中就會(huì)有這樣的設(shè)置:
*.aq_tm_processes=1
再設(shè)置實(shí)例1的aq_tm_processes為0
alter system set aq_tm_processes = 0 scope=both sid='jy1'; --create pfile='/tmp/pfile12.ora' from spfile;
此時(shí)參數(shù)文件中就會(huì)有這樣的設(shè)置:
*.aq_tm_processes=1 jy1.aq_tm_processes=0
此時(shí)就模擬了生產(chǎn)環(huán)境的現(xiàn)狀。下面來(lái)看下實(shí)際的操作過(guò)程:
SQL> SQL> alter system set aq_tm_processes = 1 scope=both sid='*'; System altered. SQL> create pfile='/tmp/pfile11.ora' from spfile; File created. SQL> show parameter aq NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ aq_tm_processes integer 1 SQL> !ps -ef|grep q00 oracle 1462 27385 0 15:27 pts/1 00:00:00 /bin/bash -c ps -ef|grep q00 oracle 1464 1462 0 15:27 pts/1 00:00:00 grep q00 oracle 26534 1 0 15:08 ? 00:00:00 ora_q002_jy1 oracle 31538 1 0 15:21 ? 00:00:00 ora_q000_jy1 SQL> SQL> alter system set aq_tm_processes = 0 scope=both sid='jy1'; System altered. SQL> create pfile='/tmp/pfile12.ora' from spfile; File created. SQL> show parameter aq NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ aq_tm_processes integer 0 SQL> !ps -ef|grep q00 oracle 2044 27385 0 15:28 pts/1 00:00:00 /bin/bash -c ps -ef|grep q00 oracle 2046 2044 0 15:28 pts/1 00:00:00 grep q00 SQL>
可以看到,確實(shí)設(shè)置為0之后q00進(jìn)程就消失了,即使再重啟實(shí)例也是一樣的,q00進(jìn)程不再會(huì)啟動(dòng)。
2.測(cè)試方案
現(xiàn)在我們要做的就是保障不更改節(jié)點(diǎn)2的設(shè)置情況下,將節(jié)點(diǎn)1的aq_tm_processes恢復(fù)默認(rèn)。
2.1 嘗試直接reset參數(shù)指定節(jié)點(diǎn)1,然后重啟驗(yàn)證?
alter system reset aq_tm_processes scope=spfile sid='jy1'; create pfile='/tmp/pfile13.ora' from spfile;
重啟節(jié)點(diǎn)1驗(yàn)證?確認(rèn)是否可以實(shí)現(xiàn)需求?
具體實(shí)際操作如下:
SQL> alter system reset aq_tm_processes scope=spfile sid='jy1'; System altered. SQL> create pfile='/tmp/pfile13.ora' from spfile; File created. SQL> show parameter aq NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ aq_tm_processes integer 0 SQL> !ps -ef|grep q00 oracle 3801 27385 0 15:32 pts/1 00:00:00 /bin/bash -c ps -ef|grep q00 oracle 3803 3801 0 15:32 pts/1 00:00:00 grep q00 SQL> startup force ORACLE instance started. Total System Global Area 599785472 bytes Fixed Size 2098112 bytes Variable Size 301993024 bytes Database Buffers 289406976 bytes Redo Buffers 6287360 bytes Database mounted. Database opened. SQL> show parameter aq NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ aq_tm_processes integer 1 SQL> !ps -ef|grep q00 oracle 4228 1 0 15:33 ? 00:00:00 ora_q000_jy1 oracle 4232 1 0 15:33 ? 00:00:00 ora_q002_jy1 oracle 5021 27385 0 15:35 pts/1 00:00:00 /bin/bash -c ps -ef|grep q00 oracle 5023 5021 0 15:35 pts/1 00:00:00 grep q00 SQL>
可以看到,答案明顯是:不可以。
因?yàn)檫@樣只會(huì)將實(shí)例1的參數(shù)reset,但是由于之前還有全局參數(shù)*,所以重啟實(shí)例1后會(huì)發(fā)現(xiàn),aq_tm_processes參數(shù)會(huì)是1。
也就是說(shuō),針對(duì)實(shí)例1的設(shè)置去掉了,自然會(huì)沿襲整體的設(shè)置。
2.2 實(shí)驗(yàn)正確的方式
有了上面的基礎(chǔ),就有了實(shí)現(xiàn)需求的思路:
我們想下,如果把全局參數(shù)也reset,會(huì)影響到節(jié)點(diǎn)2之前的設(shè)置,那么這樣,只能將節(jié)點(diǎn)2的值單獨(dú)設(shè)定,然后再reset全局參數(shù)。
alter system set aq_tm_processes = 1 scope=both sid='jy2'; --create pfile='/tmp/pfile14.ora' from spfile; alter system reset aq_tm_processes scope=spfile sid='*'; --create pfile='/tmp/pfile15.ora' from spfile; 重啟節(jié)點(diǎn)1驗(yàn)證??確認(rèn)是否可以實(shí)現(xiàn)需求? 具體實(shí)際操作如下: SQL> alter system set aq_tm_processes = 1 scope=both sid='jy2'; System altered. SQL> create pfile='/tmp/pfile14.ora' from spfile; File created. SQL> alter system reset aq_tm_processes scope=spfile sid='*'; System altered. SQL> create pfile='/tmp/pfile15.ora' from spfile; File created. SQL> startup force ORACLE instance started. Total System Global Area 599785472 bytes Fixed Size 2098112 bytes Variable Size 301993024 bytes Database Buffers 289406976 bytes Redo Buffers 6287360 bytes Database mounted. Database opened. SQL> show parameter aq NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ aq_tm_processes integer 0 SQL> !ps -ef|grep q00 oracle 7446 1 1 15:40 ? 00:00:00 ora_q000_jy1 oracle 7448 1 0 15:40 ? 00:00:00 ora_q001_jy1 oracle 7450 1 0 15:40 ? 00:00:00 ora_q002_jy1 oracle 7452 1 0 15:40 ? 00:00:00 ora_q003_jy1 oracle 7480 27385 0 15:41 pts/1 00:00:00 /bin/bash -c ps -ef|grep q00 oracle 7482 7480 0 15:41 pts/1 00:00:00 grep q00 SQL>
可以看到,真實(shí)操作測(cè)試驗(yàn)證的答案和預(yù)想的一致:可以。
注:所有創(chuàng)建pfile的步驟都可以去掉。當(dāng)時(shí)是因?yàn)橄氪_認(rèn)理論是否正確才給每一步后加了這個(gè)操作。
3.總結(jié)
那么總結(jié)歸納下,實(shí)際在客戶(hù)環(huán)境下,就是應(yīng)該做以下三個(gè)步驟完成需求:
--保障節(jié)點(diǎn)2的設(shè)置不變 alter system set aq_tm_processes=1 scope=spfile sid='jy2'; --reset節(jié)點(diǎn)1的設(shè)置 alter system reset aq_tm_processes scope=spfile sid='jy1'; --reset全局的設(shè)置 alter system reset aq_tm_processes scope=spfile sid='*';
本文知識(shí)點(diǎn)總結(jié):其實(shí)只需下面這3個(gè)知識(shí)點(diǎn)清楚就ok了:
- reset操作實(shí)際只是將這個(gè)值從spfile中移除;
- 針對(duì)某個(gè)實(shí)例級(jí)別的設(shè)置優(yōu)先級(jí)高于整體設(shè)置;
- 注意Oracle對(duì)于SET參數(shù)值這種方式,實(shí)際上少做了很多事情,簡(jiǎn)單理解就是默認(rèn)0和設(shè)置0不一樣。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
Oracle 數(shù)據(jù)庫(kù)中創(chuàng)建合理的數(shù)據(jù)庫(kù)索引
在Oracle數(shù)據(jù)庫(kù)中,創(chuàng)建索引雖然比較簡(jiǎn)單。但是要合理的創(chuàng)建索引則比較困難了。2009-06-06Oracle數(shù)據(jù)庫(kù)ORA-12560錯(cuò)誤問(wèn)題的解決辦法
這篇文章主要介紹了Oracle數(shù)據(jù)庫(kù)ORA-12560錯(cuò)誤解決辦法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05oracle數(shù)據(jù)庫(kù)慢查詢(xún)SQL實(shí)例詳解
一般的業(yè)務(wù)系統(tǒng)如果遇到性能問(wèn)題,絕大部分都是來(lái)自數(shù)據(jù)庫(kù)的,有的業(yè)務(wù)一個(gè)查詢(xún)執(zhí)行時(shí)間好幾秒,這就是我們說(shuō)說(shuō)的SQL慢查詢(xún),這篇文章主要給大家介紹了關(guān)于oracle數(shù)據(jù)庫(kù)慢查詢(xún)SQL的相關(guān)資料,需要的朋友可以參考下2024-06-06[Oracle] Data Guard 之 Redo傳輸詳解
本文先講講其中的Redo傳輸服務(wù),需要的朋友參考下2013-07-07oracle中關(guān)于case?when?then的使用
這篇文章主要介紹了oracle中關(guān)于case?when?then的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03Mac上Oracle數(shù)據(jù)庫(kù)的安裝及過(guò)程中一些問(wèn)題的解決
這篇文章主要介紹了Mac上安裝Oracle數(shù)據(jù)庫(kù)的安裝及過(guò)程中一些問(wèn)題的解決,需要的朋友可以參考下2015-12-12