Oracleset和reset的使用教程-創(chuàng)新互聯(lián)

今天小編就為大家?guī)硪黄狾racle set和reset的使用教程的文章。小編覺得挺不錯(cuò)的,為此分享給大家做個(gè)參考。一起跟隨小編過來看看吧。

創(chuàng)新互聯(lián)建站專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)、浙江網(wǎng)絡(luò)推廣、小程序設(shè)計(jì)、浙江網(wǎng)絡(luò)營(yíng)銷、浙江企業(yè)策劃、浙江品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營(yíng)等,從售前售中售后,我們都將竭誠(chéng)為您服務(wù),您的肯定,是我們大的嘉獎(jiǎng);創(chuàng)新互聯(lián)建站為所有大學(xué)生創(chuàng)業(yè)者提供浙江建站搭建服務(wù),24小時(shí)服務(wù)熱線:13518219792,官方網(wǎng)址:muchs.cn

環(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.

Oracle set和reset的使用教程

然后,在實(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ì)。

具體來看現(xiàn)在的場(chǎng)景,如果你對(duì)參數(shù)aq_tm_processes設(shè)置為0.那和本來的默認(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)容是類似這樣,有全局設(shè)置,有實(shí)例1的設(shè)置,如下:


*.aq_tm_processes=1
jy1.aq_tm_processes=0

我們知道,針對(duì)實(shí)例的設(shè)置優(yōu)先級(jí)是高的,也就是說這樣設(shè)置的效果就是實(shí)例1該參數(shù)是0,實(shí)例2該參數(shù)是1.


即:實(shí)例1無法啟動(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)狀。下面來看下實(shí)際的操作過程:

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。
也就是說,針對(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í)際在客戶環(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='*';

看完上訴內(nèi)容,你們掌握Oracle set和reset的使用方法了嗎?如果想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

分享題目:Oracleset和reset的使用教程-創(chuàng)新互聯(lián)
網(wǎng)站URL:http://muchs.cn/article14/depdde.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、服務(wù)器托管微信小程序、用戶體驗(yàn)、面包屑導(dǎo)航微信公眾號(hào)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化