程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle數據庫基礎 >> ORACLE數據庫的啟動和關閉

ORACLE數據庫的啟動和關閉

編輯:Oracle數據庫基礎
對於DBA們來說,關閉和重新啟動數據庫以便優化、調整應用的運行是經常碰到的事情。如果用
 戶已經log進如了數據庫,你用SHUTDOWN IMMEDIATE 或SHUTDOWN ABORT命令來執行關閉數據庫,
 那用戶將不能連接,直到數據庫重新啟動,用戶時常會抱怨:怎麼又要重起。其實,每次這樣的
 啟動關閉都是為了數據庫能更好的運做。這篇文章將具體介紹shutdown/startup操作時應想到的
 步驟和許多注意事項,或許這些能對你有所幫助。  
NOTE:在執行第一步前,SHUT DOWN 數據庫,不要提前關閉SQL*NET,直到你確認關閉了SERVER上
的數據庫後再關閉SQL*NET。因為一旦你關閉了SQL*NET,用戶將將失去和數據庫的會話。 

第一步---存檔或刪除老的trace files 和 logs 
當你啟動ORACLE的一個實例(INSTANCE)時,Oracle把關於該實例的診斷信息寫入指定的trace 
和 log文件。每個後台進程都增加一個TRACE文件,它被存儲在指定的目錄(該路徑由INIT.ORA 
或CONFIG.ORA文件中的BACKGROUND_DUMP_DEST參數指定)。用戶在數據庫中遇到一個內部錯誤時
也增加 USERS' TRACE文件,該文件的位置由INIT.ORA 或 CONFIG.ORA 文件中的USER_DUMP_DEST
參數指定。 

TRACE文件的個數和名稱形式由你的操作系統決定。例如在UNIX下,文件名是一個數字加下畫線加
後台進程號,類似3_12345.trc,當你下一次啟動實例時,一個新的文件將被產生,因為進程號的
不同,文件名可能是3_13245.trc 。 

由於每次啟動和關閉數據庫時,Oracle並不自動刪除TRACE文件,所以如果忽略這個步驟,那這些
沒有用的文件將占據大量的自由空間。所以DBA應該主動的管理這些文件,或刪除或存檔在別的指
定目錄下,如何管理主要是根據你自己的開發環境需要而訂了。 SQL*NET也產生LOG文件,一般叫
LISTENER.LOG,為了能知道他的位置,可以鍵入命令 
lsnrctl status 

LISTENER.LOG文件大小也隨著啟動的次數不斷的變大,所以通過妥善管理它也能有效的利用空間。 

第二步---改名ALERT LOG文件 
ALERT LOG文件也是用來記錄INSTANCE的診斷信息的。它的存放目錄也通過BACKGROUND_DUMP_DEST
參數來指定。一般情況下ALERT LOG文件命名方式為:ALERT_ .LOG。ALTER LOG文件包括了一些數
據庫主要事件信息,例如:startup,dhutdown, redo log 的使用,tablespace的改變,文件的改
變,內部錯誤信息,tablespace-backup的狀態的改變等。ALTER LOG文件是重要的,同時該文件
的大小增長的速度也很驚人,如果你不檢查他,一段時間後你想看看它將是很費勁,因為它已經
很大了,查起來也費勁。 

為了既能留下這些有用的信息,同時不至於浪費很大的空間,可以用改名的方法。你可以在任何
時候更改ALTER LOG文件名,甚至在DATABASE OPEN時。當Oracle不能找到被BACKGROUND_DUMP_DESC
指定的文件時,他將增加一個新的ALTER LOG文件。雖然改名不要求SHUTDOW,但選擇在
SHUTDOWN/STARTUP數據庫時更改名字是一個好的主意。 

NOTE:下面的幾步是在restart數據庫時做的。 

第三步---產生一個增加控制文件(CREATE CONGROLFILE )命令的文件 
為了recover一個被破壞的數據庫,你不得不用CREATE CONTROLFILE 命令來重建control files。
CREATE CONTROLFILE命令有兩個使用: 
1、在你的現有CONTROL FILES文件破化後重建它 
2、在ALTER DATABASE 級別的參數時,如:MAXDATAFILES 

你可以手輸入命令,但最好在STARTUP前發送一命令,以便你擁有最新版本的CREATE CONTROLFILE命令。
從進入SQLDBA,SERVER MANAGER或者SQL*PLUS,輸入: 
alter database backup controlfile to trace; 

該命令在USER_DUMP_DESC參數指定的路徑產生一個TRACE文件,名字可能是SIDNAME_PROCESSID.TRC,
該文件將包含針對你的數據庫的完整的CREATE CONTROLFILE 語法。 

第四步--把PACKAGES 和 PROCEDURES駐留SGA區 
眾所周知,當PL/SQL OBJECTS被一個用戶調用時,它將被存儲在SGA區的SQL共享池中,當別人再度
調用該OBJECT時直接從SGA區讀取,能感受到明顯的速度提升。所以,把常用的PACKAGES 和 
PROCEDURES在STARTUP時就載入並駐留SGA,將提高應用的整體性能。通過從新編譯、調用等方法可以
調用OBJECT(PROCEDURES 或 CURSORS)進SGA,然後用DBMS_SHARED_POOL.KEEP來駐留SGA。如下: 
alter package APPOWNER.ADD_CLIENT compile; 
execute DBMS_SHARED_POOL.KEEP('APPOWNER.ADD_CLIENT','P'); 
(P代表PROCEDURES,C代表CURSORS) 

一般每個數據庫包括兩類駐留程序: 
1、數據庫的核心PACKAGES 
2、用戶自定義的PACKAGES 
核心PACKAGES包括SYS 所有的PACKAGES,STANDARD,DBMS_SQL, DBMS_UTILITY, DIUTIL,為了查看
你的INSTANCE中那些被駐留了,查詢DBA_OBJECT_SIZE,用下面的語句: 
select Owner, 
Name, 
Type, 
Source_Size+Code_Size+Parsed_Size+Error_Size Total_Bytes 
from DBA_OBJECT_SIZE 
where Type = 'PACKAGE BODY' order by 4 desc; 
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved