1. 程式人生 > >《深入理解mybatis原理4》 MyBatis緩存機制的設計與實現

《深入理解mybatis原理4》 MyBatis緩存機制的設計與實現

針對 ces 機制 實現 ssi 查看 緩存機制 內存 完成

《深入理解mybatis原理》 MyBatis緩存機制的設計與實現

本文主要講解MyBatis非常棒的緩存機制的設計原理,給讀者們介紹一下MyBatis的緩存機制的輪廓,然後會分別針對緩存機制中的方方面面展開討論。

MyBatis將數據緩存設計成兩級結構,分為一級緩存、二級緩存:

   一級緩存是Session會話級別的緩存,位於表示一次數據庫會話的SqlSession對象之中,又被稱之為本地緩存。一級緩存是MyBatis內部實現的一個特性,用戶不能配置,默認情況下自動支持的緩存,用戶沒有定制它的權利(不過這也不是絕對的,可以通過開發插件對它進行修改);
?
二級緩存是Application應用級別的緩存,它的是生命周期很長,跟Application的生命周期一樣,也就是說它的作用範圍是整個Application應用。

MyBatis中一級緩存和二級緩存的組織如下圖所示:

技術分享圖片

一級緩存的工作機制:

  一級緩存是Session會話級別的,一般而言,一個SqlSession對象會使用一個Executor對象來完成會話操作,Executor對象會維護一個Cache緩存,以提高查詢性能。關於一級緩存的詳細實現,我已經在《深入理解mybatis原理》 MyBatis的一級緩存實現詳解 及使用註意事項 一文中有非常詳盡的討論,讀者可以前去了解。

二級緩存的工作機制:

   如上所言,一個SqlSession對象會使用一個Executor對象來完成會話操作,MyBatis的二級緩存機制的關鍵就是對這個Executor對象做文章。如果用戶配置了"cacheEnabled=true",那麽MyBatis在為SqlSession對象創建Executor對象時,會對Executor對象加上一個裝飾者:CachingExecutor,這時SqlSession使用CachingExecutor對象來完成操作請求。CachingExecutor對於查詢請求,會先判斷該查詢請求在Application級別的二級緩存中是否有緩存結果,如果有查詢結果,則直接返回緩存結果;如果緩存中沒有,再交給真正的Executor對象來完成查詢操作,之後CachingExecutor會將真正Executor返回的查詢結果放置到緩存中,然後在返回給用戶。
?
MyBatis的二級緩存設計得比較靈活,你可以使用MyBatis自己定義的二級緩存實現;你也可以通過實現org.apache.ibatis.cache.Cache接口自定義緩存;也可以使用第三方內存緩存庫,如Memcached等,這個我們會在後續的文章中詳細討論。

技術分享圖片

由於緩存機制東西太多,所以將緩存機制的敘述拆成一下幾部分(讀者可點擊查看):

  1. MyBatis的一級緩存實現詳解 及使用註意事項

  2. MyBatis的二級緩存的設計原理

  3. 自定義二級緩存(未完,待續)

  4. 使用第三方內存庫作為MyBatis的二級緩存(未完,待續)

《深入理解mybatis原理4》 MyBatis緩存機制的設計與實現