在Oracle執行個體關閉情況下如何修改spfile的參數

來源:互聯網
上載者:User

標籤:在oracle執行個體關閉情況下如何修改spfile的參數

重要說明:由於本文由本人測試並完成,其中可能還有不足之處,另外不同的環境可能也有不同的解決方案,本文僅供參考,並歡迎指證

問題描述:

在11G單機ASM中修改sga大小,修改完後,關閉instance並startup時,提示sga沒有達到最小值,因些無法啟動,而此時資料庫執行個體已經關閉,已不能在之前的那種模式修改參數,具體的操作如下:

1、查詢sga大小

SQL> show parameter sgaNAME                     TYPE     VALUE------------------------------------ ----------- ------------------------------lock_sga                 boolean     FALSEpre_page_sga                 boolean     FALSEsga_max_size                 big integer 1Gsga_target                 big integer 1G

2、修改sga大小為500M

SQL> alter system set sga_target=500M scope=spfile;System altered.

3、因為是指定參數為spfile,因此要重啟instance才能使參數生效

SQL> shutdown immediate;Database closed.Database dismounted.ORACLE instance shut down.

4、重啟instance 時,提示sga最小值應該為668M

SQL> startupORA-01078: failure in processing system parametersORA-00821: Specified value of sga_target 500M is too small, needs to be at least 668M


解決細路:

首先我們要理解一下oracle資料庫在啟動過程中調用 的參數,其順序為:

spfilesid.ora -> spfile.ora ->initsid.ora-> init.ora  從這條啟動線來說,如果第一個spfilesid.ora檔案找不到的話,它會找到二個spfile.ora檔案,如果能找到就能正常啟動,若找不到,再繼續找下一個initsid.ora檔案,一直找到最後一個init.ora檔案,說明:如果找到其中一個則會正常啟動instance


解決方案:

通過建立pfile檔案方式來啟動資料庫,然後再以pfile檔案為模板建立spfile,具體步驟是:

1、以spfile模板建立pfile檔案,並指定路徑為本地硬碟位置

create pfile=‘/oracle/initudevasm.ora‘ from spfile=‘+DGDATA02/udevasm/spfileudevasm.ora‘;

2、修改initudevasm.ora檔案,找到sga_target欄位,修改大於668M

vi /oracle/initudevasm.ora

udevasm.__db_cache_size=826277888
udevasm.__java_pool_size=4194304
udevasm.__large_pool_size=8388608
udevasm.__oracle_base=‘/oracle/app/oracle‘#ORACLE_BASE set from environment
udevasm.__pga_aggregate_target=629145600
udevasm.__sga_target=1073741824
udevasm.__shared_io_pool_size=0
udevasm.__shared_pool_size=222298112
udevasm.__streams_pool_size=0
*.audit_file_dest=‘/oracle/app/oracle/admin/udevasm/adump‘
*.audit_trail=‘db‘
*.compatible=‘11.2.0.4.0‘
*.control_files=‘+DGDATA02/udevasm/controlfile/current.256.945212019‘
*.db_block_size=8192
*.db_create_file_dest=‘+DGDATA02‘
*.db_domain=‘‘
*.db_name=‘udevasm‘
*.db_recovery_file_dest_size=3221225472
*.diagnostic_dest=‘/oracle/app/oracle‘
*.dispatchers=‘(PROTOCOL=TCP) (SERVICE=udevasmXDB)‘
udevasm.log_archive_dest_1=‘LOCATION=+DGRECOVERY/‘
*.nls_language=‘AMERICAN‘
*.nls_territory=‘AMERICA‘
*.open_cursors=300
*.pga_aggregate_target=629145600
*.processes=1000
*.remote_login_passwordfile=‘EXCLUSIVE‘
*.sessions=170
*.sga_target=754288000  --大於668M
*.undo_tablespace=‘UNDOTBS1‘
3、以pfile檔案啟動instance

SQL> startup pfile=‘/oracle/initudevasm.ora‘ORACLE instance started.Total System Global Area  751595520 bytesFixed Size            2257032 bytesVariable Size          603983736 bytesDatabase Buffers      142606336 bytesRedo Buffers            2748416 bytesDatabase mounted.Database opened.

4、以pfile檔案為模板建立spfile檔案

SQL> create spfile=‘+DGDATA02/udevasm/spfileudevasm.ora‘ from pfile=‘/oracle/initudevasm.ora‘;File created.

5、關閉執行個體,並重新啟動spfile,因為在在建立spfile時已經預設指定原來的路徑,並把原來的spfile檔案覆蓋了,所以只要直接啟動即可

SQL> shutdown immediate;Database closed.Database dismounted.ORACLE instance shut down.SQL> startupORACLE instance started.Total System Global Area  751595520 bytesFixed Size            2257032 bytesVariable Size          603983736 bytesDatabase Buffers      142606336 bytesRedo Buffers            2748416 bytesDatabase mounted.Database opened.

6、查詢修改後的sga大小

SQL> show parameter sgaNAME                     TYPE     VALUE------------------------------------ ----------- ------------------------------lock_sga                 boolean     FALSEpre_page_sga                 boolean     FALSEsga_max_size                 big integer 720Msga_target                 big integer 720M

通過上面查詢則判斷已經修改並恢複成功

總結:

    1、當資料庫發生因為有關參數檔案異常無法啟動正常時,可以先把原理理解,然後通過建立pfile與spfile檔案方式解決啟動問題。

    2、要備份有關資料庫參數檔案以防止誤操作導致資料庫無法正常啟動


本文出自 “我主梁緣” 部落格,請務必保留此出處http://xiaocao13140.blog.51cto.com/6198256/1946083

在Oracle執行個體關閉情況下如何修改spfile的參數

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.