乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      Oracle spfile 參數(shù)文件

       LuciferLiu 2021-12-10

      目錄

      ?? 前言

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

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

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

      ?? spfile 介紹

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

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

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

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

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

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

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

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

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

      show parameter spfile

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

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

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

      • Windows: $ORACLE_HOME/database

      • Linux: $ORACLE_HOME/dbs

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

      • pfile 文件格式為:initSID.ora

      • spfile 文件格式為:spfileSID.ora

      ?? 啟動(dòng)優(yōu)先級(jí)

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

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

      ?? 拓展:

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

      所以,我做了個(gè)小測(cè)試:

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

      sqlplus / as sysdbashutdown immediateexit


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

      cd $ORACLE_HOME/dbscp spfileorcl.ora spfile.ora

      3、重新啟動(dòng)數(shù)據(jù)庫(kù)

      sqlplus / as sysdba
      startup
      show parameter spfile

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

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

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


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

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

      export ORACLE_SID=lucifer
      sqlplus / as sysdba
      startup

      根據(jù)上圖實(shí)驗(yàn),實(shí)例名為 lucifer,數(shù)據(jù)庫(kù)也是可以成功啟動(dòng)??。

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

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

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

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

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

      ?? 實(shí)例講解

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

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

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

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

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

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

      sqlplus / as sysdba
      create spfile from pfile;

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

      4、重啟數(shù)據(jù)庫(kù),默認(rèn)會(huì)使用 spfile 文件啟動(dòng):

      sqlplus / as sysdbashutdown immediate
      startup

      image.png

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

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

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

      問題重現(xiàn)

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

      此時(shí),由于 spfile 是二進(jìn)制文件,無法直接打開修改,因此需要通過手動(dòng)生成 pfile 文件進(jìn)行修改啟動(dòng)。

      解決步驟

      1、手動(dòng)生成 pfile 文件

      sqlplus / as sysdba
      create pfile from spfile;

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

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

      cd $ORACLE_HOME/dbsvi initorcl.ora

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

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

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

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

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

      sqlplus / as sysdba
      create spfile from pfile;

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

      sqlplus / as sysdbashutdown immediate
      startup

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

      5、注意點(diǎn)

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

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

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

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

      ?? 注意:

      因此,在最后生成 spfile 時(shí),需要手動(dòng)指定 spfile 的路徑為 ASM 磁盤中的路徑!

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


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

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

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

        0條評(píng)論

        發(fā)表

        請(qǐng)遵守用戶 評(píng)論公約

        類似文章 更多