時(shí)間:2015-06-28 00:00:00 來(lái)源:IT貓撲網(wǎng) 作者:網(wǎng)管聯(lián)盟 我要評(píng)論(0)
Oracle數(shù)據(jù)庫(kù)能運(yùn)行在2種模式下:歸檔模式(archivelog)和非歸檔模式(noarchivelog)。歸檔模式能提高Oracle數(shù)據(jù)庫(kù)的可恢復(fù)性,生產(chǎn)數(shù)據(jù)庫(kù)都應(yīng)該運(yùn)行在此模式下,歸檔模式應(yīng)該和相應(yīng)的備份策略相結(jié)合,只有歸檔模式?jīng)]有相應(yīng)的備份策略只會(huì)帶來(lái)麻煩。
檢查歸檔模式命令:
SQL> archive log list Database log mode No Archive Mode Automatic archival Disabled Archive destination USE_DB_RECOVERY_FILE_DEST Oldest online log sequence 15 Current log sequence 17
設(shè)置歸檔模式:
SQL> shutdown immediate; Database closed. Database dismounted. ORACLE instance shut down. SQL> startup mount ORACLE instance started. Total System Global Area 1258291200 bytes Fixed Size 1219160 bytes Variable Size 318768552 bytes Database Buffers 922746880 bytes Redo Buffers 15556608 bytes Database mounted. SQL> alter database archivelog; Database altered. SQL> alter database open; Database altered. SQL> archive log list; Database log mode Archive Mode Automatic archival Enabled Archive destination USE_DB_RECOVERY_FILE_DEST Oldest online log sequence 15 Next log sequence to archive 17 Current log sequence 17
如果需要停止歸檔模式,使用:alter database noarchivelog 命令。Oracle10g之前,你還需要修改初始化參數(shù)使數(shù)據(jù)庫(kù)處于自動(dòng)歸檔模式。在pfile/spfile中設(shè)置如下參數(shù):
log_archive_start = true
重啟數(shù)據(jù)庫(kù)此參數(shù)生效,此時(shí)數(shù)據(jù)庫(kù)處于自動(dòng)歸檔模式。也能在數(shù)據(jù)庫(kù)啟動(dòng)過(guò)程中,手工執(zhí)行:
archive log start
使數(shù)據(jù)庫(kù)啟用自動(dòng)歸檔,不過(guò)重啟后數(shù)據(jù)庫(kù)仍然處于手工歸檔模式。10g使用db_recovery_file_dest來(lái)作為歸檔日志的存放地。
SQL> show parameter db_recovery NAME TYPE VALUE db_recovery_file_dest string /home/oracle/ora10g/flash_reco very_area/ db_recovery_file_dest_size big integer 20G
能修改db_recovery_file_dest_size參數(shù)的大小
alter system set db_recovery_file_dest_size=21474836480
一、
重做日志文件把對(duì)數(shù)據(jù)文件的修改在寫(xiě)入數(shù)據(jù)文件之前記錄下來(lái)。日志文件以一種循環(huán)的方式被寫(xiě)入信息。當(dāng)一個(gè)日志組被寫(xiě)滿時(shí),回自動(dòng)向另一個(gè)日志組寫(xiě)入。管理員可以手工切換當(dāng)前日志組。alter system switch logfile 可以切換當(dāng)前的日志組。當(dāng)日志組發(fā)生切換時(shí),oracle向新的重做日志組分配一個(gè)日志序列號(hào)。當(dāng)存在大量的事務(wù)時(shí)必須調(diào)整重做日志文件的大小,以避免頻繁的日志切換發(fā)生。重做日志文件被順序的寫(xiě)在磁盤(pán)上,如果磁盤(pán)沒(méi)有其他活動(dòng),I/O將會(huì)很快。應(yīng)該把重做日志文件保存在單獨(dú)的磁盤(pán)上,以獲取良好的性能。尤其不要把經(jīng)常處于活動(dòng)狀態(tài)的SYSTEM,UNDOTBS,SYSAUX的表空間或索引表空間文件保存到同一塊磁盤(pán)上。因?yàn)橹挥性谑聞?wù)的請(qǐng)求被寫(xiě)到重做日志后,請(qǐng)求才能被完成。最大限度的提高重做日志的吞吐量是oracle性能優(yōu)化首先考慮的因素。當(dāng)發(fā)生重做日志切換而生成一個(gè)新的檢查點(diǎn)時(shí),DBWn就會(huì)寫(xiě)臟緩沖器塊。這樣會(huì)影響oracle的性能??梢酝ㄟ^(guò)fast_start_mttr_target初始化參數(shù)來(lái)調(diào)整檢查點(diǎn)。
每個(gè)數(shù)據(jù)庫(kù)都有自己的聯(lián)機(jī)重做日志組,一個(gè)聯(lián)機(jī)重做日志組有多個(gè)重做日志成員,每個(gè)日志成員有單獨(dú)的操作系統(tǒng)文件。在一個(gè)rac配置(這種配置中單個(gè)數(shù)據(jù)庫(kù)裝有多個(gè)實(shí)例),每個(gè)實(shí)例有一個(gè)聯(lián)機(jī)重做日志線程,每個(gè)實(shí)例的lgwr進(jìn)程都寫(xiě)到相同的聯(lián)機(jī)重做日志文件。因此oracle必須跟蹤數(shù)據(jù)庫(kù)實(shí)例修改來(lái)自那個(gè)實(shí)例。
當(dāng)多路復(fù)用重做日志文件時(shí),應(yīng)該把一個(gè)組的成員保存在不同的磁盤(pán)上。以避免單點(diǎn)故障的發(fā)生。如果重做日志文件組的所有成員都無(wú)法寫(xiě)入數(shù)據(jù),oracle將被掛起。Dba可以在創(chuàng)建數(shù)據(jù)庫(kù)時(shí)創(chuàng)建多個(gè)聯(lián)機(jī)重做日志文件的副本。
對(duì)日志的操作如下:
a. 創(chuàng)建新的重做日志組:
Alter database add logfile
Group 3 (‘/ora02/oradata/mydb01/redo0301.log’,
’/ora03/oradata/mdb01/redo0302.log’) size 10m;
如果省略group子句,oracle分配一個(gè)有效的編號(hào),如下:
Alter database add logfile
b. 添加新的組成員:
alter database add logfile member
‘/ora04/oradata/mydb01/redo0203.log’ to group 2;(向第二組中添加新的成員)
c.重命名日志成員:
在重命名日志組成員之前新的目標(biāo)必須已經(jīng)存在。Oracle的sql命令只是把控制文件中的內(nèi)部指針指向新的日志文件。Dba需要用操作系統(tǒng)命令來(lái)重命名此日志文件。步驟如下:
1.關(guān)閉數(shù)據(jù)庫(kù)
2.使用操作系統(tǒng)命令重命名或移動(dòng)日志文件
3. 啟動(dòng)數(shù)據(jù)庫(kù)實(shí)例(start mount),重命名控制文件中的日志文? 件成員。Alter database rename file?? ‘old_redo_file_name’ to ‘new_redo_file_name’;
4.打開(kāi)數(shù)據(jù)庫(kù) alter database open
5.備份控制文件
D.刪除重做日志組:
將要被刪除的重做日志組不能是活動(dòng)的日志組。Alter database drop logfile group 3;。當(dāng)重做日志文件被刪除后,相關(guān)的操作系統(tǒng)文件也被刪除,相關(guān)的數(shù)據(jù)庫(kù)控制文件也給更新。
E.使用和刪除重做日志組相同的方式,dba可以只刪除一個(gè)非活動(dòng)的重做日志組的成員。
Alter database drop logfile member ‘/ora04/oradata/mydb01/redo0203.log’;
f. 創(chuàng)建聯(lián)機(jī)重做日志文件:
當(dāng)重做日志組成員遭到破壞時(shí),可以刪除并重新添加這個(gè)重做日志組或組成員。
二、
檔案重做日志文件:
它是聯(lián)機(jī)重做日志文件的一個(gè)副本。Lgwr和arcn進(jìn)程的故障都會(huì)引起數(shù)據(jù)庫(kù)的掛起。只有當(dāng)arcn進(jìn)程把聯(lián)機(jī)重做日志寫(xiě)到歸檔地后,才可以向此重做日志組成員寫(xiě)入數(shù)據(jù)。
設(shè)置歸檔目的地:
可以在參數(shù)初始化文件中的log_archive_dest_n來(lái)定義歸檔目的地。歸檔目的地可以在本地計(jì)算機(jī)上,也可在遠(yuǎn)程的數(shù)據(jù)庫(kù)服務(wù)器上。定義語(yǔ)法如下:
LOG_ARCHIVE_DEST_n= "null_string" |
(service=tnsnames_name |
LOCATION= ‘directory_name’)
[MANDATORY | OPTIONAL]
[REOPEN[=integer]]
例1:
LOG_ARCHIVE_DEST_1=((LOCATION=’/archive/MYDB01’) MANDATORU REOPEN=60)定義歸檔日志的位置為/archive/MYDB01,mandatory子句的定義向這個(gè)位置寫(xiě)日志的操作必須的成功的。Reopen子句定義在日志寫(xiě)入失敗時(shí),下次嘗試寫(xiě)入操作的時(shí)間間隔。缺省是300秒。
例2:
LOG_ARCHIVE_DEST_@=(SERVICE=STDBY01) OPTIONAL REOPEN;語(yǔ)句中的stdby01的連接到遠(yuǎn)程數(shù)據(jù)庫(kù)的oracle net連接串。由于寫(xiě)操作是可選的,所以數(shù)據(jù)庫(kù)活動(dòng)繼續(xù),當(dāng)arcn進(jìn)程不能寫(xiě)檔案日志文件時(shí),進(jìn)程將立即嘗試重新寫(xiě)入(這個(gè)動(dòng)作有reopen子句來(lái)定義)。
Log_archive_min_succeed_dest:定義最少歸檔日志的副本數(shù)量。
Log_archive_format:定義歸檔日志文件采用的名稱和使用的格式??梢允褂妙A(yù)定義變量來(lái)構(gòu)造每個(gè)歸檔日志文件的名稱。變量如下:
%s????? 日志序列號(hào)
%t????? 線程號(hào)
%r????? 復(fù)位日志id
%d????? 數(shù)據(jù)庫(kù)id
定義歸檔日志名稱的變量至少包含%s,%t,%r,當(dāng)多個(gè)數(shù)據(jù)庫(kù)實(shí)例的歸檔日志采用相同的歸檔日志位置時(shí),還必須定義%d。例如:%t_%s_%r.dbf
關(guān)鍵詞標(biāo)簽:Oracle
相關(guān)閱讀
熱門(mén)文章 Oracle中使用alter table來(lái)增加,刪除,修改列的語(yǔ)法 oracle中使用SQL語(yǔ)句修改字段類(lèi)型-oracle修改SQL語(yǔ)句案例 誤刪Oracle數(shù)據(jù)庫(kù)實(shí)例的控制文件 為UNIX服務(wù)器設(shè)置Oracle全文檢索
人氣排行 oracle中使用SQL語(yǔ)句修改字段類(lèi)型-oracle修改SQL語(yǔ)句案例 Oracle中使用alter table來(lái)增加,刪除,修改列的語(yǔ)法 ORACLE SQL 判斷字符串是否為數(shù)字的語(yǔ)句 ORACLE和SQL語(yǔ)法區(qū)別歸納(1) oracle grant 授權(quán)語(yǔ)句 ORACLE修改IP地址后如何能夠使用 如何加速Oracle大批量數(shù)據(jù)處理 Oracle刪除表的幾種方法