1. 程式人生 > 資料庫 >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=1
jy1.aq_tm_processes=0

我們知道,針對例項的設定優先順序是高的,也就是說這樣設定的效果就是例項1該引數是0,例項2該引數是1.

即:例項1無法啟動q00小工程序,例項2可以啟動q00小工程序。

構建測試環境模擬生產:

先設定aq_tm_processes為1:

alter system set aq_tm_processes = 1 scope=both sid='*';
--create pfile='/tmp/pfile11.ora' from spfile;

此時引數檔案中就會有這樣的設定:

*.aq_tm_processes=1

再設定例項1的aq_tm_processes為0

alter system set aq_tm_processes = 0 scope=both sid='jy1';
--create pfile='/tmp/pfile12.ora' from spfile;

此時引數檔案中就會有這樣的設定:

*.aq_tm_processes=1
jy1.aq_tm_processes=0

此時就模擬了生產環境的現狀。下面來看下實際的操作過程:

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> 

可以看到,確實設定為0之後q00程序就消失了,即使再重啟例項也是一樣的,q00程序不再會啟動。

2.測試方案

現在我們要做的就是保障不更改節點2的設定情況下,將節點1的aq_tm_processes恢復預設。

2.1 嘗試直接reset引數指定節點1,然後重啟驗證?

alter system reset aq_tm_processes scope=spfile sid='jy1';
create pfile='/tmp/pfile13.ora' from spfile;

重啟節點1驗證?確認是否可以實現需求?

具體實際操作如下:

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> 

可以看到,答案明顯是:不可以。

因為這樣只會將例項1的引數reset,但是由於之前還有全域性引數*,所以重啟例項1後會發現,aq_tm_processes引數會是1。
也就是說,針對例項1的設定去掉了,自然會沿襲整體的設定。

2.2 實驗正確的方式

有了上面的基礎,就有了實現需求的思路:

我們想下,如果把全域性引數也reset,會影響到節點2之前的設定,那麼這樣,只能將節點2的值單獨設定,然後再reset全域性引數。

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;

重啟節點1驗證??確認是否可以實現需求?

具體實際操作如下:

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> 

可以看到,真實操作測試驗證的答案和預想的一致:可以。

注:所有建立pfile的步驟都可以去掉。當時是因為想確認理論是否正確才給每一步後加了這個操作。

3.總結

那麼總結歸納下,實際在客戶環境下,就是應該做以下三個步驟完成需求:

--保障節點2的設定不變
alter system set aq_tm_processes=1 scope=spfile sid='jy2';
--reset節點1的設定
alter system reset aq_tm_processes scope=spfile sid='jy1';
--reset全域性的設定
alter system reset aq_tm_processes scope=spfile sid='*';

本文知識點總結:其實只需下面這3個知識點清楚就ok了:

  • reset操作實際只是將這個值從spfile中移除;
  • 針對某個例項級別的設定優先順序高於整體設定;
  • 注意Oracle對於SET引數值這種方式,實際上少做了很多事情,簡單理解就是預設0和設定0不一樣。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對我們的支援。