濮阳杆衣贸易有限公司

主頁 > 知識庫 > Oracle參數(shù)設(shè)置教程之set和reset的實(shí)用案例

Oracle參數(shù)設(shè)置教程之set和reset的實(shí)用案例

熱門標(biāo)簽:海南400電話哪里辦理 分布式呼叫中心 濟(jì)南地圖標(biāo)注公司 貴陽電話外呼系統(tǒng)哪家好 安陽外呼系統(tǒng)免費(fèi) 南寧人工智能電銷機(jī)器人費(fèi)用 呼倫貝爾智能手機(jī)地圖標(biāo)注 400電話是不是免費(fèi)申請 圖像地圖標(biāo)注

前言

本文主要給大家介紹了關(guān)于Oracle參數(shù)設(shè)置之set和reset的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面話不多說了,來一起看看詳細(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),這個默認(rèn)0和我們手工將其SET設(shè)置成0,效果是完全不一樣的。

與同事交流此事,最終得知一個技術(shù)細(xì)節(jié):

Oracle中,使用SET設(shè)置參數(shù)值實(shí)際上是少做很多事情的,如果你想恢復(fù)Oracle的默認(rèn)值,最有效的辦法就是RESET該值,這樣,才會一切都按照Oracle默認(rèn)的設(shè)計。

具體來看現(xiàn)在的場景,如果你對參數(shù)aq_tm_processes設(shè)置為0.那和本來的默認(rèn)0是完全不一樣的。

如果是設(shè)置0,所有q00小工進(jìn)程都會關(guān)閉不會再啟動。如果是默認(rèn)0,q00小工進(jìn)程是可以啟動的。

1.構(gòu)建測試環(huán)境

目前生產(chǎn)的參數(shù)內(nèi)容是類似這樣,有全局設(shè)置,有實(shí)例1的設(shè)置,如下:

*.aq_tm_processes=1
jy1.aq_tm_processes=0

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

即:實(shí)例1無法啟動q00小工進(jìn)程,實(shí)例2可以啟動q00小工進(jìn)程。

構(gòu)建測試環(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è)置:

*.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è)置:

*.aq_tm_processes=1
jy1.aq_tm_processes=0

此時就模擬了生產(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)程不再會啟動。

2.測試方案

現(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)檫@樣只會將實(shí)例1的參數(shù)reset,但是由于之前還有全局參數(shù)*,所以重啟實(shí)例1后會發(fā)現(xiàn),aq_tm_processes參數(shù)會是1。
也就是說,針對實(shí)例1的設(shè)置去掉了,自然會沿襲整體的設(shè)置。

2.2 實(shí)驗(yàn)正確的方式

有了上面的基礎(chǔ),就有了實(shí)現(xiàn)需求的思路:

我們想下,如果把全局參數(shù)也reset,會影響到節(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í)操作測試驗(yàn)證的答案和預(yù)想的一致:可以。

注:所有創(chuàng)建pfile的步驟都可以去掉。當(dāng)時是因?yàn)橄氪_認(rèn)理論是否正確才給每一步后加了這個操作。

3.總結(jié)

那么總結(jié)歸納下,實(shí)際在客戶環(huán)境下,就是應(yīng)該做以下三個步驟完成需求:

--保障節(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='*';

本文知識點(diǎn)總結(jié):其實(shí)只需下面這3個知識點(diǎn)清楚就ok了:

  • reset操作實(shí)際只是將這個值從spfile中移除;
  • 針對某個實(shí)例級別的設(shè)置優(yōu)先級高于整體設(shè)置;
  • 注意Oracle對于SET參數(shù)值這種方式,實(shí)際上少做了很多事情,簡單理解就是默認(rèn)0和設(shè)置0不一樣。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • oracle初始化參數(shù)設(shè)置
  • Oracle數(shù)據(jù)庫中的控制文件管理以及常用參數(shù)設(shè)置

標(biāo)簽:許昌 涼山 遼源 合肥 郴州 焦作 滁州 南充

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Oracle參數(shù)設(shè)置教程之set和reset的實(shí)用案例》,本文關(guān)鍵詞  Oracle,參數(shù),設(shè)置,教程,之,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Oracle參數(shù)設(shè)置教程之set和reset的實(shí)用案例》相關(guān)的同類信息!
  • 本頁收集關(guān)于Oracle參數(shù)設(shè)置教程之set和reset的實(shí)用案例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    和田县| 将乐县| 桂林市| 米脂县| 宁河县| 淅川县| 通河县| 丰台区| 神池县| 亚东县| 黄石市| 平顺县| 清涧县| 永仁县| 无为县| 财经| 马山县| 衡水市| 永城市| 泰来县| 新昌县| 綦江县| 乐东| 库车县| 汪清县| 兴化市| 剑阁县| 荔浦县| 上饶县| 宿州市| 大宁县| 额尔古纳市| 淮滨县| 安阳市| 尉犁县| 诸城市| 和平区| 宜黄县| 丁青县| 武川县| 大冶市|