SCN与数据恢复关联
一、各种SCN简介:如图,控制文件中有系统SCN号,针对每个数据文件还有文件SCN号、结束SCN号(如四个数据文件就有4个对应的文件SCN号、结束SCN号)数据文件头部
一、各种SCN简介:
如图,控制文件中有系统SCN号,针对每个数据文件还有文件SCN号、结束SCN号(如四个数据文件就有4个对应的文件SCN号、结束SCN号)
数据文件头部有开始SCN号。都是为了保证数据文件的一致性
正常情况下:系统SCN、文件SCN、文件头部的开始SCN应该一样,结束SCN为null
系统SCN:
SQL> select checkpoint_change# from v$database;
CHECKPOINT_CHANGE#
------------------
617242
文件SCN:
SQL> select name,checkpoint_change# from v$datafile;
NAME CHECKPOINT_CHANGE#
-------------------------------------------------- ------------------
/u01/app/oracle/oradata/jiagulun/system01.dbf 617242
/u01/app/oracle/oradata/jiagulun/undotbs01.dbf 617242
/u01/app/oracle/oradata/jiagulun/sysaux01.dbf 617242
/u01/app/oracle/oradata/jiagulun/users01.dbf 617242
/u01/app/oracle/oradata/jiagulun/example01.dbf 617242
/u01/app/oracle/oradata/jiagulun/data1_01_dbf 617242
结束SCN:
SQL> select name,last_change# from v$datafile;
NAME LAST_CHANGE#
-------------------------------------------------- ------------
/u01/app/oracle/oradata/jiagulun/system01.dbf
/u01/app/oracle/oradata/jiagulun/undotbs01.dbf
/u01/app/oracle/oradata/jiagulun/sysaux01.dbf
/u01/app/oracle/oradata/jiagulun/users01.dbf
/u01/app/oracle/oradata/jiagulun/example01.dbf
/u01/app/oracle/oradata/jiagulun/data1_01_dbf
数据文件头部开始SCN:
SQL> select name,checkpoint_change# from v$datafile_header;
NAME CHECKPOINT_CHANGE#
-------------------------------------------------- ------------------
/u01/app/oracle/oradata/jiagulun/system01.dbf 617242
/u01/app/oracle/oradata/jiagulun/undotbs01.dbf 617242
/u01/app/oracle/oradata/jiagulun/sysaux01.dbf 617242
/u01/app/oracle/oradata/jiagulun/users01.dbf 617242
/u01/app/oracle/oradata/jiagulun/example01.dbf 617242
/u01/app/oracle/oradata/jiagulun/data1_01_dbf 617242
每一条日志都有SCN,每个日志组文件的头部有两个SCN first SCN和next SCN
first SCN:即这个文件组中第一条日志的SCN,等于上一组的next SCN。
next SCN:即这个文件组中最后一条日志的SCN,等于下一组的first SCN。
二、SCN如何保证数据库文件一致性(如何确认需要恢复)?
正常关闭:将所有buffer cache脏块写到磁盘,同时更新系统SCN、文件SCN,,数据头部开始SCN,同时结束SCN写上与系统SCN、文件SCN、数据头部开始SCN都一样的时间点(关闭时间)
非正常关闭:结束SCN为null,未正常写上。开启数据库时检测到结束SCN为null,则需要实例恢复。
数据文件丢失:例如当1号DBF文件丢失了,从备份中拷贝一个备份的1号DBF文件过来,此时文件头部的SCN比较旧,与控制文件系统SCN号对比,oracle则发现需要做恢复。则用跑日志将其SCN跑到与控制文件中文件SCN一样。
控制文件丢失:控制文件和数据文件都换成旧的,此时光对比控制文件中的SCN号和数据文件头部的SCN号还不能确认需不需要恢复,oracle还要对比on disk rba scn,如果on disk rba scn比控制文件中的SCN号和数据文件头部的SCN号都新,则要实例恢复。
用SCN号确认使用哪些日志组来恢复实例:
目前系统SCN号为617242:
SQL> select checkpoint_change# from v$database;
CHECKPOINT_CHANGE#
------------------
617242
此时日志组1first SCN为617242,则需要日志组1恢复即可;
试着经过两次日志组切换:
SQL> alter system switch logfile;
System altered.
SQL> alter system switch logfile;
System altered.
此时系统当前最新的文件SCN仍然是617242
SQL> select checkpoint_change# from v$database;
CHECKPOINT_CHANGE#
------------------
617242
那么这时候数据库实例崩溃使用哪些日志组恢复呢?
此时617242在日志组1,按照序列号8-10,日志组3是最新日志,此时需要日志组1、2、3恢复。
日志中active代表组中存在日志对应的脏块还没有写到磁盘中。
执行
SQL> alter system flush buffer_cache;
System altered.
后,日志组active变为inactive:
而此时控制文件中的SCN也更新为:
SQL> select checkpoint_change# from v$database;
CHECKPOINT_CHANGE#
------------------
628825
此时如果数据库实例非正常关闭,则需要日志组3来恢复。
三、总结:
控制文件中系统SCN,文件SCN等于最旧的active日志文件组的first SCN,实例恢复需要active和current日志组。
控制文件中的系统SCN,文件SCN用于确认数据恢复的所需要的重做日志文件组。
确认文件组后根据控制文件中的LRBA地址去跑日志跑到on disk rba地址。
CKPT进程只是将LRBA地址写到控制文件中,而控制文件中的系统SCN,文件SCN和数据头部SCN的更新是当一个日志组由active变为inactive时更新的,结束SCN则是关闭数据库时候更新的。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

windows7用戶在啟動時遇到了系統登錄檔遺失或損壞的現象,像這種情況該怎麼解決呢?你先強制重啟電腦,以後按F8鍵,在開啟的頁面中選擇安全模式進到,之後在選單列找到命令提示字元開啟,輸入SFC/SCANNOW指令並回車實行,這時候系統就會自動對電腦缺少或已損壞的安裝檔進行修復。 windows7系統登錄檔遺失或損壞怎麼辦1、最先開機自檢之後,立刻按住F8鍵,應用方向鍵挑選安全模式,敲打回車即可。 2.以後點選開始按鈕,挑選指令提示符,以管理者的身分運作。 3.最後在彈出的提示符號中輸入SFC/

1.binlogbinlog用於記錄資料庫執行的寫入性操作(不包括查詢)信息,以二進制的形式保存在磁碟中。 binlog是mysql的邏輯日誌,並且由Server層進行記錄,使用任何儲存引擎的mysql資料庫都會記錄binlog日誌。邏輯日誌:可以簡單得理解為sql語句;物理日誌:MySQL中資料都是保存在資料頁中的,實體日誌記錄的是資料頁上的變更;在這裡插入程式碼片binlog是透過追加的方式進行寫入的,可以透過max_binlog_size參數設定每個binlog檔案的大小,當檔案大小達到給定值

很多小夥伴不知道diskgenius資料怎麼恢復,所以下面小編就分享了diskgenius資料恢復的相關教程,一起去看看吧,相信對大家會有幫助。首先,在DiskGenius的主介面上方的硬碟分區圖中,可以直接選擇目標分區,右鍵點擊。接著,在彈出的快速選單中,找到並點選「已刪除或格式化的檔案復原」選單項,如圖所示。在第二步驟中,彈出恢復選項窗口,確保勾選「恢復已刪除的檔案」、「完整恢復」和「額外掃描已知檔案類型」這三個選項。第三步:點擊右側的「選擇檔案類型」按鈕,在彈出的視窗中指定您需要恢復的文件

PHP參數遺失問題的解決方案在開發PHP程式的過程中,經常會遇到參數遺失的問題,這可能是由於前端傳遞的參數不完整、後端接收參數的方式不正確等原因造成的。在本文中,我們將針對PHP參數遺失問題提供一些解決方案,並附上具體的程式碼範例。一、前端傳參問題使用GET方法傳遞參數當使用GET方法傳遞參數時,參數會以URL參數的形式附加在請求的URL後面。在後端接收參數時

ThinkPHP6資料備份與復原:保障資料的安全性隨著網路的快速發展,資料已成為極為重要的資產。因此,資料的安全性備受關注。在Web應用開發中,資料備份與復原是確保資料安全的重要一環。在本文中,我們將介紹如何使用ThinkPHP6框架進行資料備份與恢復,以保障資料的安全性。一、資料備份資料備份是指將資料庫中的資料以某種方式複製或儲存。這樣即使在數據

前言MySQL中有六種日誌文件,分別是:重做日誌(redolog)、回滾日誌(undolog)、二進位日誌(binlog)、錯誤日誌(errorlog)、慢查詢日誌(slowquerylog)、一般查詢日誌(generallog ),中繼日誌(relaylog)。 1.什麼是redolog? redolog又稱重做日誌文件,用於記錄事務操作的變化,記錄的是資料修改之後的值,不管交易是否提交都會記錄下來。當實例和媒體失敗(mediafailure)時,redolog檔案就能派上用場,如資料庫掉電,Inn

Laravel是一個流行的PHPWeb應用程式框架,提供了許多快速且簡單的方式來建立高效、安全且可擴展的Web應用程式。在開發Laravel應用程式時,我們經常需要考慮資料恢復的問題,即如何在資料遺失或損壞的情況下恢復資料並保證應用程式的正常運作。在本文中,我們將介紹如何使用Laravel中間件來實現資料復原功能,並提供具體的程式碼範例。一、什麼是Lara

硬碟磁區壞了怎麼解決硬碟磁區壞了是一個常見的硬體故障,它可能導致資料遺失,影響電腦的效能。了解和解決硬碟扇區壞了的問題是非常重要的。本文將介紹硬碟磁區的概念,討論常見的硬碟磁區壞了的原因以及解決方法。一、什麼是硬碟磁區?在介紹如何解決硬碟磁區壞了的問題之前,我們先來了解什麼是硬碟磁區。硬碟磁區是硬碟上最小的可讀寫單元,它是硬碟中的一小段空間,用
