RAC cache fusion機制實現(xiàn)原理分析
更新時間:2012年12月03日 12:08:05 作者:
本文將詳細介紹RAC cache fusion機制實現(xiàn)原理,需要了解更多的朋友可以參考下
在單實例中,進程要想修改數(shù)據(jù)塊,必須在數(shù)據(jù)塊的當前版本(Currentcopy)上進行修改RAC環(huán)境也一樣
這便涉及到一系列問題:
如何獲得數(shù)據(jù)塊的版本在集群節(jié)點間的分布圖?
如何知道哪個節(jié)點擁有的是當前版本?
如何完成傳遞過程?
這一系列問題的解決依靠內存融合技術(cachefusion)
cachefusion通過高速的privateinterconnect,在實例間進行數(shù)據(jù)塊傳遞
這是RAC最核心的工作機制,他把所有實例的SGA虛擬成一個大的SGA區(qū)
每當不同的實例請求相同的數(shù)據(jù)塊,這個數(shù)據(jù)塊就需要在實例間進行傳遞
在Oracle7的OPS中,這種傳遞是通過磁盤完成的,也叫“Disk-BasedPing”
也就是第1個實例必須先把這個數(shù)據(jù)塊寫回磁盤,然后第2個實例再從磁盤上讀取這個數(shù)據(jù)塊
這種依靠磁盤來完成數(shù)據(jù)傳遞極大影響系統(tǒng)性能
在Oracle8i引入“Net-BasedPing”通過PrivateInterconnect來傳遞數(shù)據(jù)塊
但是8i只能傳遞沒有修改過的數(shù)據(jù)塊,對于“臟塊”還是要通過磁盤來傳遞,這一點和OPS一樣
在Oracle9i的cachefusion,所有的數(shù)據(jù)塊,無論修改的或者沒有修改的,都可以通過PrivateInterconnect傳遞
系統(tǒng)系能得到極大的改善
在cachefusion中,每個數(shù)據(jù)塊都會被映射成一個cachefusion資源,或者說是一個PCM資源
PCM資源實際上是一個數(shù)據(jù)結構,資源的名稱就是DBA(數(shù)據(jù)塊地址)
每個進程對數(shù)據(jù)的請求都是分步完成:
①把DBA轉換成PCM資源名稱
②把這個PCM資源請求提交給DLM(分布式鎖管理器)
③DLM進行GlobalLock的申請、釋放活動,只有進程獲得了PCMLock,才能繼續(xù)下一步
也就是實例首先要獲得數(shù)據(jù)塊的使用權
整個cachefusion有兩個服務組成:GCS和GES
⑴GCS服務負責數(shù)據(jù)塊在實例間的傳遞
由后臺進程LMSn完成
⑵GES服務負責鎖管理
在多個實例之間協(xié)調對數(shù)據(jù)塊的訪問順序,保證數(shù)據(jù)的一致性訪問
由后臺進程LMD完成
這便涉及到一系列問題:
如何獲得數(shù)據(jù)塊的版本在集群節(jié)點間的分布圖?
如何知道哪個節(jié)點擁有的是當前版本?
如何完成傳遞過程?
這一系列問題的解決依靠內存融合技術(cachefusion)

cachefusion通過高速的privateinterconnect,在實例間進行數(shù)據(jù)塊傳遞
這是RAC最核心的工作機制,他把所有實例的SGA虛擬成一個大的SGA區(qū)
每當不同的實例請求相同的數(shù)據(jù)塊,這個數(shù)據(jù)塊就需要在實例間進行傳遞
在Oracle7的OPS中,這種傳遞是通過磁盤完成的,也叫“Disk-BasedPing”
也就是第1個實例必須先把這個數(shù)據(jù)塊寫回磁盤,然后第2個實例再從磁盤上讀取這個數(shù)據(jù)塊
這種依靠磁盤來完成數(shù)據(jù)傳遞極大影響系統(tǒng)性能
在Oracle8i引入“Net-BasedPing”通過PrivateInterconnect來傳遞數(shù)據(jù)塊
但是8i只能傳遞沒有修改過的數(shù)據(jù)塊,對于“臟塊”還是要通過磁盤來傳遞,這一點和OPS一樣
在Oracle9i的cachefusion,所有的數(shù)據(jù)塊,無論修改的或者沒有修改的,都可以通過PrivateInterconnect傳遞
系統(tǒng)系能得到極大的改善
在cachefusion中,每個數(shù)據(jù)塊都會被映射成一個cachefusion資源,或者說是一個PCM資源
PCM資源實際上是一個數(shù)據(jù)結構,資源的名稱就是DBA(數(shù)據(jù)塊地址)
每個進程對數(shù)據(jù)的請求都是分步完成:
①把DBA轉換成PCM資源名稱
②把這個PCM資源請求提交給DLM(分布式鎖管理器)
③DLM進行GlobalLock的申請、釋放活動,只有進程獲得了PCMLock,才能繼續(xù)下一步
也就是實例首先要獲得數(shù)據(jù)塊的使用權
整個cachefusion有兩個服務組成:GCS和GES
⑴GCS服務負責數(shù)據(jù)塊在實例間的傳遞
由后臺進程LMSn完成
⑵GES服務負責鎖管理
在多個實例之間協(xié)調對數(shù)據(jù)塊的訪問順序,保證數(shù)據(jù)的一致性訪問
由后臺進程LMD完成
相關文章
Windows系統(tǒng)下Oracle數(shù)據(jù)庫每天自動備份
linux和unix下面使用shell可以很方便實現(xiàn),如果windows環(huán)境下可以結合計劃任務實現(xiàn)自動備份,下面通過本文給大家介紹實現(xiàn)方法,需要的朋友參考下吧2016-12-12Oracle數(shù)據(jù)庫中表空間的基本管理操作小結
這篇文章主要介紹了Oracle數(shù)據(jù)庫中表空間的基本管理方法小結,包括創(chuàng)建表空間和獲取表空間大小等的操作命令,需要的朋友可以參考下2015-12-12oracle分區(qū)表創(chuàng)建(自動按年、月、日分區(qū))實戰(zhàn)記錄
Oracle的表分區(qū)功能通過改善可管理性、性能和可用性,從而為各式應用程序帶來了極大的好處,下面這篇文章主要給大家介紹了關于oracle分區(qū)表創(chuàng)建(自動按年、月、日分區(qū))的相關資料,需要的朋友可以參考下2023-06-06oracle導出sql語句的結果集和保存執(zhí)行的sql語句(深入分析)
本篇文章是對oracle導出sql語句的結果集與保存執(zhí)行的sql語句進行了詳細的分析介紹,需要的朋友參考下2013-05-05