最近開始重構公司一套手機論壇系統(為什么我不說wap論壇,是因為需要針對不同的手機瀏覽器,實現自動適配成wap、html以及wap2.0版本的頁面)。原系統存在架構層次不清晰(表現層全jsp,直接配合數據層獲取數據),訪問速度慢的問題。其使用的OR映射框架是Hibernate,鑒于Hibernate的一些不滿足需要情況下,我們在重構的時候換成了iBatis,為了加快訪問速度,采用了iBatis的緩存技術。
iBatis的緩存配置比較簡單易懂,以我使用的iBatis2.3為例,做以下配置即可實現對某些查詢進行緩存:
1、在sqlMap文件中加入cacheModel的配置:
<cacheModel id="model-cache" type="MEMORY" >
<flushInterval seconds="60"/>
<flushOnExecute statement="insertProduct"/>
<flushOnExecute statement="updateProduct"/>
<flushOnExecute statement="deleteProduct"/>
<property name="size" value="1000" />
</cacheModel>
這個地方要注意的是,如果在sqlMapConfig里面設置了useStatementNamespaces="true",那么上面的flushOnExecute中的statement里面需要帶上namespace,如<flushOnExecute statement="Product.insertProduct"/>,如果useStatementNamespaces="false",則可以直接按上面的寫。
2、配置需要進行cache的sql statment:
<statement id="getProductList" parameterClass="int" cacheModel="model-cache">
select * from PRODUCT where PRD_CAT_ID = #value#
</statement>
配置好這兩步就可實現iBatis的緩存了,下面解釋一下含義:
1步中,cacheModel的id屬性用于后面的statement引用,type屬性標識采用何種cache方式,可選的有:
“MEMORY” (com.ibatis.db.sqlmap.cache.memory.MemoryCacheController) 。MEMORY cache 實現使用 reference 類型來管理 cache 的行為。垃圾收集器可以根據 reference類型判斷是否要回收 cache 中的數據。MEMORY實現適用于沒有統一的對象重用模式的應用,或內存不足的應用。
“LRU” (com.ibatis.db.sqlmap.cache.lru.LruCacheController) 。LRU Cache 實現用“近期最少使用”原則來確定如何從 Cache 中清除對象。當 Cache溢出時,最近最少使用的對象將被從 Cache 中清除。使用這種方法,如果一個特定的對象總是被使用,它將保留在 Cache 中,而且被清除的可能性最小。對于在較長的期間內,某些用戶經常使用某些特定對象的情況(例如,在 PaginatedList 和常用的查詢關鍵字結果集中翻頁) ,LRU Cache 是一個不錯的選擇。
“FIFO” (com.ibatis.db.sqlmap.cache.fifo.FifoCacheController) 。FIFO Cache 實現用“先進先出”原則來確定如何從 Cache 中清除對象。當 Cache 溢出時,最先進入 Cache 的對象將從 Cache 中清除。對于短時間內持續引用特定的查詢而后很可能不再使用的情況,FIFO Cache 是很好的選擇。
“OSCACHE” (com.ibatis.db.sqlmap.cache.oscache.OSCacheController) 。OSCACHE Cache 實現是OSCache2.0緩存引擎的一個 Plugin。它具有高度的可配置性,分布式,高度的靈活性。
flushInterval 屬性是配置自動更新緩存的周期,可以是hours,minutes,seconds或milliseconds。這一點我測試了一下,設置的60秒更新,通過觀察日志,在60秒內,第一次查詢數據庫,之后iBatis會對同樣的sql查詢直接返回。超過60秒后的第一次查詢,又會執行一次查詢。這樣看了,這個更新的周期可理解為第一次同樣的查詢可維持在cache中的時長,超過這個時長的第一次查詢會觸發實際的數據庫操作。
flushOnExecute這是標識什么時候觸發更新,statement的名字就是后面的statement的id。
statement節中設置了cacheModel,就會把這個sql跟cache關聯起來。
是不是很簡單呢,這里面我覺得比較關鍵的地方就是cacheModel的type選擇,一般來說用memory就可以了,但一些特殊的應用,需要根據情況需要配置不同的更適合的cache,以進一步提高查詢效率。
本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/paulluo0739/archive/2009/06/10/4257144.aspx