首頁 系統教程 Linux Oracle參數之set與reset設定

Oracle參數之set與reset設定

Mar 20, 2024 pm 07:10 PM
linux linux教程 紅帽 linux系統 linux指令 linux認證 紅帽linux linux視頻

Oracle參數設定之set與reset的實際案例

環境:Oracle 10.2.0.5 RAC

需求:節點1的aq_tm_processes要求恢復默認,節點2設定要求保持不變

  • 1.建置測試環境
  • 2.測試方案
  • 3.總​​結

背景介紹:
從10.2官檔可以查到aq_tm_processes參數,看到該參數的預設值為0,我們姑且叫做它為預設0.

Oracle參數之set與reset設定

#然後,在實際上發現,這個預設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不一樣。

以上是Oracle參數之set與reset設定的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Linux實際上有什麼好處? Linux實際上有什麼好處? Apr 12, 2025 am 12:20 AM

Linux適用於服務器、開發環境和嵌入式系統。 1.作為服務器操作系統,Linux穩定高效,常用於部署高並發應用。 2.作為開發環境,Linux提供高效的命令行工具和包管理系統,提升開發效率。 3.在嵌入式系統中,Linux輕量且可定制,適合資源有限的環境。

oracle如何查看實例名 oracle如何查看實例名 Apr 11, 2025 pm 08:18 PM

在 Oracle 中查看實例名的方法有三種:命令行中使用 "sqlplus" 和 "select instance_name from v$instance;" 命令。在 SQL*Plus 中使用 "show instance_name;" 命令。通過操作系統的任務管理器、Oracle Enterprise Manager 或檢查環境變量 (Linux 上的 ORACLE_SID)。

oracle數據庫卸載教程 oracle數據庫卸載教程 Apr 11, 2025 pm 06:24 PM

要卸載 Oracle 數據庫:停止 Oracle 服務,移除 Oracle 實例,刪除 Oracle 主目錄,清除註冊表項(僅限 Windows),刪除環境變量(僅限 Windows)。卸載前請備份數據。

將Docker與Linux一起使用:綜合指南 將Docker與Linux一起使用:綜合指南 Apr 12, 2025 am 12:07 AM

在Linux上使用Docker可以提高開發和部署效率。 1.安裝Docker:使用腳本在Ubuntu上安裝Docker。 2.驗證安裝:運行sudodockerrunhello-world。 3.基本用法:創建Nginx容器dockerrun--namemy-nginx-p8080:80-dnginx。 4.高級用法:創建自定義鏡像,使用Dockerfile構建並運行。 5.優化與最佳實踐:使用多階段構建和DockerCompose,遵循編寫Dockerfile的最佳實踐。

oracle安裝之後如何使用 oracle安裝之後如何使用 Apr 11, 2025 pm 07:51 PM

安裝 Oracle 後,可通過以下步驟使用:創建數據庫實例。連接到數據庫。創建用戶。創建表。插入數據。查詢數據。導出數據。導入數據。

apache80端口被佔用怎麼辦 apache80端口被佔用怎麼辦 Apr 13, 2025 pm 01:24 PM

當 Apache 80 端口被佔用時,解決方法如下:找出佔用該端口的進程並關閉它。檢查防火牆設置以確保 Apache 未被阻止。如果以上方法無效,請重新配置 Apache 使用不同的端口。重啟 Apache 服務。

apache怎麼啟動 apache怎麼啟動 Apr 13, 2025 pm 01:06 PM

啟動 Apache 的步驟如下:安裝 Apache(命令:sudo apt-get install apache2 或從官網下載)啟動 Apache(Linux:sudo systemctl start apache2;Windows:右鍵“Apache2.4”服務並選擇“啟動”)檢查是否已啟動(Linux:sudo systemctl status apache2;Windows:查看服務管理器中“Apache2.4”服務的狀態)啟用開機自動啟動(可選,Linux:sudo systemctl

如何在Debian上監控Nginx SSL性能 如何在Debian上監控Nginx SSL性能 Apr 12, 2025 pm 10:18 PM

本文介紹如何在Debian系統上有效監控Nginx服務器的SSL性能。我們將使用NginxExporter將Nginx狀態數據導出到Prometheus,再通過Grafana進行可視化展示。第一步:配置Nginx首先,我們需要在Nginx配置文件中啟用stub_status模塊來獲取Nginx的狀態信息。在你的Nginx配置文件(通常位於/etc/nginx/nginx.conf或其包含文件中)中添加以下代碼段:location/nginx_status{stub_status

See all articles