MyBatis之六:緩存


  MyBatis 3中的緩存實現的很多改進都已經實現了,使得它更加強大而且易於配置。默認情況下是沒有開啟緩存的,除了局部的session緩存,可以增強變現而且處理循環依賴也是必須的。要開啟二級緩存,你需要在你的SQL映射文件中(Mapper.xml)添加一行:<cache/>
  字面上看就是這樣。這個簡單語句的效果如下:
  1、 映射語句文件中的所有select語句將會被緩存。
  2、映射語句文件中的所有insert,update和delete語句會刷新緩存。
  3、緩存會使用Least Recently Used(LRU,最近最少使用的)算法來收回。
  4、根據時間表(比如no Flush Interval,沒有刷新間隔),緩存不會以任何時間順序來刷新。
  5、緩存會存儲列表集合或對象(無論查詢方法返回什么)的1024個引用。
  6、緩存會被視為是read/write(可讀/可寫)的緩存,意味着對象檢索不是共享的,而且可以安全地被調用者修改,而不干擾其他調用者或線程所做的潛在修改。


  所有的這些屬性都可以通過緩存元素的屬性來修改。比如:<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>
  這個更高級的配置創建了一個FIFO緩存,並每隔60秒刷新,存數結果對象或列表的512個引用,而且返回的對象被認為是只讀的,因此在不同線程中的調用者之間修改它們會導致沖突。


  可用的收回策略有:
  1、 LRU – 最近最少使用的:移除最長時間不被使用的對象。
  2、FIFO – 先進先出:按對象進入緩存的順序來移除它們。
  3、SOFT – 軟引用:移除基於垃圾回收器狀態和軟引用規則的對象。
  4、WEAK – 弱引用:更積極地移除基於垃圾收集器狀態和弱引用規則的對象。
  默認的是LRU。


  flushInterval(刷新間隔)可以被設置為任意的正整數,而且它們代表一個合理的毫秒形式的時間段。默認情況是不設置,也就是沒有刷新間隔,緩存僅僅調用語句時刷新。
  size(引用數目)可以被設置為任意正整數,要記住你緩存的對象數目和你運行環境的可用內存資源數目。默認值是1024。
  readOnly(只讀)屬性可以被設置為true或false。只讀的緩存會給所有調用者返回緩存對象的相同實例。因此這些對象不能被修改。這提供了很重要的性能優勢。可讀寫的緩存會返回緩存對象的拷貝(通過序列化)。這會慢一些,但是安全,因此默認是false。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM