日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

Oracle spfile 參數(shù)文件

 LuciferLiu 2021-12-10

目錄

?? 前言

上篇講了 Oracle pfile 參數(shù)文件 ,這篇講講 spfile 參數(shù)文件!

Oracle數(shù)據(jù)庫啟動時,第一步開啟到nomount狀態(tài),需要使用到參數(shù)文件。

spfile 也是參數(shù)文件的一種,全稱:服務(wù)器參數(shù)文件(Server Parameter Files)

?? spfile 介紹

spfileSID.ora 文件就是 spfile 參數(shù)文件,是二進制文件。

從 Oracle 9i 開始,Oracle 引入 spfile 文件,使用spfile用戶可以通過 ALTER SYSTEM 或者 ALTER SESSION 來修改參數(shù),而不再需要通過手工修改。

使用 spfile 參數(shù)文件有以下好處:

  • 動態(tài)參數(shù)的更改可以立即生效,用戶可以選擇使更改只應(yīng)用于當(dāng)前實例還是應(yīng)用到spfile,或者都應(yīng)用;

  • 可以徹底告別手工修改初始化參數(shù)文件,也就大大減少了人為錯誤的發(fā)生;

  • spfile 是一個二進制文件,可以使用rman進行備份,增加數(shù)據(jù)庫的安全,便于恢復(fù);

所以,現(xiàn)在基本都是默認使用 spfile 來啟動數(shù)據(jù)庫,但是如果由于 spfile 修改參數(shù)數(shù)據(jù)庫無法啟動時,就只能使用 pfile 修改參數(shù)進行啟動。

如何查看當(dāng)前數(shù)據(jù)庫使用的是不是 spfile 啟動?

連接數(shù)據(jù)庫之后,執(zhí)行以下命令:

show parameter spfile

如果以下框選的地方不為空,則代表當(dāng)前數(shù)據(jù)庫使用 spfile 啟動,否則是 pfile 啟動。

?? spfile 參數(shù)文件位置

單機數(shù)據(jù)庫,spfile 參數(shù)文件通常存在于以下目錄下:

  • Windows: $ORACLE_HOME/database

  • Linux: $ORACLE_HOME/dbs

RAC 集群,spfile 通常是存放在 ASM 磁盤中,以上目錄僅存放 pfile 文件。

  • pfile 文件格式為:initSID.ora

  • spfile 文件格式為:spfileSID.ora

?? 啟動優(yōu)先級

如果同時有 pfile 和 spfile 文件,數(shù)據(jù)庫啟動的優(yōu)先級是如何的?

官方說法: spfileSID.ora > initorcl.ora

?? 拓展:

我看到網(wǎng)上一個有趣的說法,如果使用 spfileSID.ora 文件復(fù)制出一個 spfile.ora 文件,那么優(yōu)先級順序是:spfileSID.ora > spfile.ora > initorcl.ora。

所以,我做了個小測試:

1、首先關(guān)閉數(shù)據(jù)庫:

sqlplus / as sysdbashutdown immediateexit


2、從 spfileSID.ora 復(fù)制一個 spfile.ora 文件:

cd $ORACLE_HOME/dbscp spfileorcl.ora spfile.ora

3、重新啟動數(shù)據(jù)庫

sqlplus / as sysdba
startup
show parameter spfile

從上圖可以看出,優(yōu)先級最高的是 spfileSID.ora,驗證沒有問題。

4、刪除 spfileSID.ora 文件,重啟數(shù)據(jù)庫

cd $ORACLE_HOME/dbs
rm -rf spfileorcl.ora
sqlplus / as sysdba
shutdown immediate
startup
show parameter spfile


根據(jù)上圖所示,居然真的優(yōu)先識別到的是 spfile.ora 文件,那就有一個問題,如果是隨便 export 一個 ORACLE_SID,是不是也能啟動呢?

5、先關(guān)閉當(dāng)前數(shù)據(jù)庫,設(shè)置一個新的 ORACLE_SID,啟動數(shù)據(jù)庫

export ORACLE_SID=lucifer
sqlplus / as sysdba
startup

根據(jù)上圖實驗,實例名為 lucifer,數(shù)據(jù)庫也是可以成功啟動??。

所以,如果 ORACLE_SID 設(shè)置錯誤的情況下,如果存在 spfile.ora 文件,那么優(yōu)先級會跳過 spfileSID.ora 文件,直接優(yōu)先選擇 spfile.ora 文件來啟動數(shù)據(jù)庫。

6、最后刪除所有 spfile 文件,重啟數(shù)據(jù)庫

source ~/.bash_profilerm -rf spfile*
sqlplus / as sysdbashutdown immediate
startup

當(dāng)沒有 spfile 文件時,最后只能選擇 initSID.ora 文件來進行啟動數(shù)據(jù)庫。

因此,優(yōu)先級順序:spfileSID.ora > spfile.ora > initorcl.ora 是沒有問題的。

?? 實例講解

① 從 pfile 切換為 spfile 啟動數(shù)據(jù)庫

有一些特殊情況下需要切換使用參數(shù)文件,如何切換使用 pfile 和 spfile?

1、首先,使用 pfile 參數(shù)文件啟動數(shù)據(jù)庫:

sqlplus / as sysdba
startup pfile=$ORACLE_HOME/dbs/initorcl.ora

2、為了測試會生成 spfile 參數(shù)文件,我提前刪除它:

3、確保當(dāng)前數(shù)據(jù)庫環(huán)境是由 pfile 文件啟動,連接 sqlplus:

sqlplus / as sysdba
create spfile from pfile;

執(zhí)行以上命令,可以根據(jù) pfile 生成 spfile 文件,保存在默認的參數(shù)文件目錄下。

4、重啟數(shù)據(jù)庫,默認會使用 spfile 文件啟動:

sqlplus / as sysdbashutdown immediate
startup

image.png

此時,數(shù)據(jù)庫已經(jīng)使用 spfile 啟動。

② 使用 spfile 啟動數(shù)據(jù)庫后修改參數(shù)錯誤,導(dǎo)致數(shù)據(jù)庫無法啟動

一般什么情況下必須用到 pfile 參數(shù)文件?

問題重現(xiàn)

比如,你在數(shù)據(jù)庫中通過 alter system 設(shè)置了數(shù)據(jù)庫參數(shù),關(guān)閉數(shù)據(jù)庫后,重新打開數(shù)據(jù)庫時報錯無法打開。

此時,由于 spfile 是二進制文件,無法直接打開修改,因此需要通過手動生成 pfile 文件進行修改啟動。

解決步驟

1、手動生成 pfile 文件

sqlplus / as sysdba
create pfile from spfile;

注意:以上命令可以在未開啟數(shù)據(jù)庫時進行執(zhí)行,pfile生成路徑也可以指定:pfile=生成路徑/pfile文件名。

2、編輯 pfile 文件,修改錯誤設(shè)置的參數(shù)

cd $ORACLE_HOME/dbsvi initorcl.ora

打開之后,修改 processes 參數(shù)為正確?的數(shù)值即可。

3、使用修改后的 pfile 參數(shù)文件啟動數(shù)據(jù)庫

sqlplus / as sysdba
startup pfile=$ORACLE_HOME/dbs/initorcl.ora

此時,數(shù)據(jù)庫已經(jīng)成功打開。

4、數(shù)據(jù)庫啟動成功后,切換回 spfile 重新啟動數(shù)據(jù)庫
由于當(dāng)前數(shù)據(jù)庫是使用 pfile 進行啟動,需要修改為spfile啟動。

sqlplus / as sysdba
create spfile from pfile;

修改完之后,重啟數(shù)據(jù)庫生效:

sqlplus / as sysdbashutdown immediate
startup

如上,數(shù)據(jù)庫已經(jīng)成功恢復(fù)為 spfile 啟動,并且當(dāng)前數(shù)據(jù)庫參數(shù)也是正確的。

5、注意點

如果是 RAC 集群操作時,由于 RAC 的 spfile 文件是保存在 ASM 磁盤中,所以是跟 pfile 文件配合進行使用。

比如,下方的 RAC 集群示例:

# ASM磁盤下的 spfile 文件ASMCMD> pwd+data/orcl
ASMCMD> ls spfile*
spfileorcl.ora# 一節(jié)點 ORACLE_HOME/dbs 目錄下的 pfile 文件[oracle@orcl1 dbs]$ cat initorcl1.ora 
SPFILE='+DATA/orcl/spfileorcl.ora'

通過上述示例可以發(fā)現(xiàn),RAC 實際上使用的還是 pfile 去啟動的,但是將 spfile 路徑寫在 pfile 文件中。

?? 注意:

因此,在最后生成 spfile 時,需要手動指定 spfile 的路徑為 ASM 磁盤中的路徑!

需要注意 $ORACLE_HOME/dbs 目錄下不能存在 spfile[ORACLE_SID].ora 文件,否則啟動時優(yōu)先選擇 $ORACLE_HOME/dbs 下的 spfile 文件。


本次分享到此結(jié)束啦~

如果覺得文章對你有幫助,點贊、收藏、關(guān)注、評論,一鍵四連支持,你的支持就是我創(chuàng)作最大的動力。

    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多