亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

淺談oracle SCN機制

2024-08-29 14:00:34
字體:
來源:轉載
供稿:網友

SCN(System Change Number)作為oracle中的一個重要機制,在數據恢復、Data Guard、Streams復制、RAC節點間的同步等各個功能中起著重要作用。理解SCN的運作機制,可以幫助你更加深入地了解上述功能。

在理解SCN之前,我們先看下oracle事務中的數據變化是如何寫入數據文件的:

1、事務開始;

2、在buffer cache中找到需要的數據塊,如果沒有找到,則從數據文件中載入buffer cache中;

3、事務修改buffer cache的數據塊,該數據被標識為“臟數據”,并被寫入log buffer中;

4、事務提交,LGWR進程將log buffer中的“臟數據”寫入redo log file中;

5、當發生checkpoint,CKPT進程更新所有數據文件的文件頭中的信息,DBWn進程則負責將Buffer Cache中的臟數據寫入到數據文件中。

經過上述5個步驟,事務中的數據變化最終被寫入到數據文件中。但是,一旦在上述中間環節時,數據庫意外宕機了,在重新啟動時如何知道哪些數據已經寫入數據文件、哪些沒有寫呢(同樣,在DG、streams中也存在類似疑問:redo log中哪些是上一次同步已經復制過的數據、哪些沒有)?SCN機制就能比較完善的解決上述問題。

SCN是一個數字,確切的說是一個只會增加、不會減少的數字。正是它這種只會增加的特性確保了Oracle知道哪些應該被恢復、哪些應該被復制。

總共有4中SCN:系統檢查點(System Checkpoint)SCN、數據文件檢查點(Datafile Checkpoint)SCN、結束SCN(Stop SCN)、開始SCN(Start SCN)。其中其面3中SCN存在于控制文件中,最后一種則存在于數據文件的文件頭中。

在控制文件中,System Checkpoint SCN是針對整個數據庫全局的,因而之存在一個,而Datafile Checkpoint SCN和Stop SCN是針對每個數據文件的,因而一個數據文件就對應在控制文件中存在一份Datafile Checkpoint SCN和Stop SCN。在數據庫正常運行期間,Stop SCN(通過視圖v$datafile的字段last_change#可以查詢)是一個無窮大的數字或者說是NULL。

在一個事務提交后(上述第四個步驟),會在redo log中存在一條redo記錄,同時,系統為其提供一個最新的SCN(通過函數dbms_flashback.get_system_change_number可以知道當前的最新SCN),記錄在該條記錄中。如果該條記錄是在redo log被清空(日志滿做切換時或發生checkpoint時,所有變化日志已經被寫入數據文件中),則其SCN被記錄為redo log的low SCN。以后在日志再次被清空前寫入的redo記錄中SCN則成為Next SCN。

當日志切換或發生checkpoint(上述第五個步驟)時,從Low SCN到Next SCN之間的所有redo記錄的數據就被DBWn進程寫入數據文件中,而CKPT進程則將所有數據文件(無論redo log中的數據是否影響到該數據文件)的文件頭上記錄的Start SCN(通過視圖v$datafile_header的字段checkpoint_change#可以查詢)更新為Next SCN,同時將控制文件中的System Checkpoint SCN(通過視圖v$database的字段checkpoint_change#可以查詢)、每個數據文件對應的Datafile Checkpoint(通過視圖v$datafile的字段checkpoint_change#可以查詢)也更新為Next SCN。但是,如果該數據文件所在的表空間被設置為read-only時,數據文件的Start SCN和控制文件中Datafile Checkpoint SCN都不會被更新。

那系統是如何產生一個最新的SCN的?實際上,這個數字是由當時的timestamp轉換過來的。每當需要產生一個最新的SCN到redo記錄時,系統獲取當時的timestamp,將其轉換為數字作為SCN。我們可以通過函數SCN_TO_TIMESTAMP(10g以后)將其轉換回timestamp:

SQL> select dbms_flashback.get_system_change_number, SCN_TO_TIMESTAMP(dbms_flashback.get_system_change_number) from dual; GET_SYSTEM_CHANGE_NUMBER------------------------SCN_TO_TIMESTAMP(DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER)---------------------------------------------------------------------------    287707675617-AUG-07 02.15.26.000000000 PM

 

也可以用函數timestamp_to_scn將一個timestamp轉換為SCN:

SQL> select timestamp_to_scn(SYSTIMESTAMP) as scn from dual;   SCN----------2877078439

最后,SCN除了作為反映事務數據變化并保持同步外,它還起到系統的“心跳”作用——每隔3秒左右系統會刷新一次系統SCN。

下面,在簡單介紹一下SCN如何在數據庫恢復中起作用。

數據庫在正常關閉(shutdown immediate/normal)時,會先做一次checkpoint,將log file中的數據寫入數據文件中,將控制文件、數據文件中的SCN(包括控制文件中的Stop SCN)都更新為最新的SCN。

數據庫異常/意外關閉不會或者只更新部分Stop SCN。

當數據庫啟動時,Oracle先檢查控制文件中的每個Datafile Checkpoint SCN和數據文件中的Start SCN是否相同,再檢查每個Datafile Checkpoint SCN和Stop SCN是否相同。如果發現有不同,就從Redo Log中找到丟失的SCN,重新寫入數據文件中進行恢復。具體的數據恢復過程這里就不再贅述。

SCN作為Oracle中的一個重要機制,在多個重要功能中起著“控制器”的作用。了解SCN的產生和實現方式,幫助DBA理解和處理恢復、DG、Streams復制的問題。

最后提一句,利用SCN機制,在Oracle10g、11g中又增加了一些很實用的功能——數據庫閃回、數據庫負載重現等。

總結

以上就是本文關于淺談oracle SCN機制的全部內容,希望對大家有所幫助。有什么問題可以隨時留言,小編會及時回復大家的。感謝大家對VeVb武林網的支持!


注:相關教程知識閱讀請移步到oracle教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97国产在线视频| 欧美激情国产日韩精品一区18| 亚洲欧美成人一区二区在线电影| 久久精品视频免费播放| 日韩激情av在线播放| 色与欲影视天天看综合网| 中文字幕日韩精品有码视频| 国产日韩精品综合网站| 国产精品电影观看| 上原亚衣av一区二区三区| 亚洲国产高清自拍| 中文国产亚洲喷潮| 国产精品女视频| 亚洲国产精品va在线看黑人| 精品视频偷偷看在线观看| 亚洲福利小视频| 国产精品2018| 亚洲成人精品久久| 国产精品视频公开费视频| 久久精品中文字幕一区| 欧美精品在线极品| 欧美极品少妇xxxxⅹ裸体艺术| 欧美一级淫片播放口| 清纯唯美日韩制服另类| 日韩免费不卡av| 国产精品视频久久久久| 日韩精品视频中文在线观看| 亚洲色图综合久久| 超碰日本道色综合久久综合| 国产精品丝袜白浆摸在线| 日韩精品视频中文在线观看| 视频直播国产精品| 日韩中文在线中文网三级| 国产精品久久久久9999| 欧美精品久久久久久久久久| 欧美制服第一页| 中文字幕欧美视频在线| 欧美激情视频在线免费观看 欧美视频免费一| 国产视频在线一区二区| 亚洲天堂2020| 国产www精品| 亚洲人成网7777777国产| 久久综合88中文色鬼| 国自产精品手机在线观看视频| 欧美午夜美女看片| 欧美成人激情视频免费观看| 亚洲一区制服诱惑| 国产91久久婷婷一区二区| 成人黄色影片在线| 最新国产成人av网站网址麻豆| 日韩欧美中文字幕在线观看| 在线观看日韩av| 亚洲综合av影视| 日韩极品精品视频免费观看| 亚洲天堂免费观看| 91免费电影网站| 精品亚洲国产视频| 亚洲国产精品va在线看黑人| 国产精品99久久久久久久久久久久| 亚洲欧美日韩成人| 97久久精品人人澡人人爽缅北| 精品欧美一区二区三区| 久久久久99精品久久久久| 日本午夜在线亚洲.国产| 国产精品国产自产拍高清av水多| 日韩在线中文视频| 国产999在线观看| 2018日韩中文字幕| 国产成人精品a视频一区www| 91精品国产色综合久久不卡98| 国产成一区二区| 在线精品国产欧美| 色多多国产成人永久免费网站| 色偷偷av一区二区三区乱| 国产福利成人在线| 一本色道久久综合亚洲精品小说| 欧美日韩一区二区免费视频| 国产精品久久久久久久久粉嫩av| 中文日韩在线视频| 欧美成人午夜免费视在线看片| 中文字幕在线观看亚洲| 成人黄色生活片| 欧美大全免费观看电视剧大泉洋| 欧美日韩成人在线视频| 亚洲天堂男人的天堂| 久久综合电影一区| 成人天堂噜噜噜| 亚洲人成电影网站| 欧美精品少妇videofree| 中文字幕日韩在线观看| 91精品国产高清久久久久久久久| 久久av资源网站| 欧美中文在线观看| 91免费综合在线| 久久久久久伊人| 91精品国产九九九久久久亚洲| 欧美性猛交xxxxx水多| 国产视频一区在线| 中日韩午夜理伦电影免费| 国模gogo一区二区大胆私拍| 欧美亚洲成人网| 亚洲a级在线观看| 欧美日本精品在线| 亚洲理论片在线观看| 亚洲精品视频中文字幕| 91福利视频在线观看| 91tv亚洲精品香蕉国产一区7ujn| 国语自产精品视频在线看一大j8| 久久成人精品一区二区三区| 日韩精品亚洲视频| 久久97精品久久久久久久不卡| 国产成人精品免费久久久久| 亚洲国产精品成人av| 欧美午夜电影在线| 国产精品久久久久av免费| 最近2019中文字幕第三页视频| 久久久精品中文字幕| 欧美中文字幕在线| 国产成人在线播放| 久久久在线观看| 国产欧美日韩综合精品| 国产精品女人久久久久久| 中文字幕亚洲无线码在线一区| 国产美女主播一区| 成人精品久久av网站| 日韩最新中文字幕电影免费看| 欧美激情第一页xxx| 亚洲伊人第一页| 亚洲精品一区二区在线| 亚洲影院色无极综合| 亚洲aⅴ日韩av电影在线观看| 欧美成人合集magnet| 中文字幕精品在线视频| 国产成人精品久久亚洲高清不卡| 亚洲国产一区二区三区在线观看| 中文字幕在线观看日韩| 国产精品99久久久久久久久久久久| www.亚洲人.com| www.亚洲成人| 国产91露脸中文字幕在线| 日韩av在线免费| 在线性视频日韩欧美| 日本精品一区二区三区在线播放视频| 国产91精品青草社区| 欧美成人精品影院| 久久99久国产精品黄毛片入口| 亚洲美女久久久| 亚洲人成网7777777国产| 日韩在线观看视频免费| 亚洲欧美综合另类中字| 一个人看的www久久| 国产精品亚洲片夜色在线| www国产91| 日本不卡免费高清视频| 亚洲最大福利视频网| 一个色综合导航| 欧美日韩aaaa| 久久精品中文字幕免费mv| 国产精品一区二区三区久久| 亚洲字幕在线观看| 国产精品久久久久999| 欧美一区二区三区图| 欧美午夜电影在线| 日本一欧美一欧美一亚洲视频|