隨筆-4  評論-7  文章-0  trackbacks-0

          Hibernate在進行數據讀取時會先在緩存里找,緩存中不存在時再去數據庫查詢,合理使用hibernate緩存能夠有效的利用內存,減少物理數據庫調用的次數.

           

          ORM緩存策略

          1.事務級緩存(session level cache)

          session生命周期的緩存,關閉session即消亡

          2.應用級/進程級緩存(sessionFactory level cache)

          某個應用中的共享緩存,多個事務可以共享,在sessionFactory層實現,所有sessionFactory創建的session可以共享.

          3.分布式緩存

          多個JVM共享的緩存,通過遠程機制實現緩存數據同步,任意實例修改數據,所有的JVM都要更新緩存.

           

          Hibernate數據緩存

          1.內部緩存(session level)一級緩存

          是事務級的緩存,session中維護的一個Map,Map的key是包含了數據類型和id,從數據庫加載的數據都會進入Map緩存中,通過session加載數據時會先在session緩存里找,一級緩存是session的private數據,session實例消亡就清除了,在應用中就保持在一次請求的開始和結束之間.

          一般由Hibernate自動維護,也支持手動維護

          session.evit(Object obj) 將持久化對象從一級緩存中清除.

          session.clear()  清空一級緩存

          session.contains(Object obj) 判斷指定的對象是否存在于一級緩存中. 

          session.flush() 刷新一級緩存區的內容,使緩存與數據庫數據保持同步. 

           

          2.二級緩存(sessionFactory level)

          包含了應用級和分布式的緩存,由本sessionFactory的所有session實例共享,session操作時會先查一級緩存,然后查二級緩存,最后再查物理數據庫.要使用二級緩存必須要進行配置.

           

          適合用緩存的數據

          1.不會被其他應用修改

          包括直接用JDBC修改等,因為其他應用修改了數據之后hibernate并不知道,不能自動更新緩存,不過可以手動更新緩存

          2.數據大小可以接受,畢竟內存資源也不多

          3.數據更新頻率低(比如數據字典等常量數據)

          4.可能被系統頻繁使用

          5.非關鍵的數據

          6.不會被并發訪問的數據

           

          常用的二級緩存插件

          EHCache  org.hibernate.cache.EhCacheProvider 

          OSCache  org.hibernate.cache.OSCacheProvider 

          SwarmCahe  org.hibernate.cache.SwarmCacheProvider 提供了分布式

          JBossCache  org.hibernate.cache.TreeCacheProvider 提供了分布式

           

          EHCache二級緩存配置方法

          1.啟用二級緩存首先要在hibernate.cfg.xml配置

          <hibernate-configuration>  

             <session-factory>  

                <!-- 配置二級緩存插件EHCache的Provider類-->  

                <property name="hibernate.cache.provider_class">  

                   org.hibernate.cache.EhCacheProvider  

                </property>  

                <!-- 啟動"查詢緩存" -->  

                <property name="hibernate.cache.use_query_cache">  

                   true  

                </property>  

             </session-factory>  

           </hibernate-configuration> 

           

          2.然后配置cache的配置文件ehcache.xml

          <ehcache>  

            <!-- maxElementsInMemory為緩存對象的最大數目,

          eternal設置是否永遠不過期,

          timeToIdleSeconds對象處于空閑狀態的最多秒數,

          timeToLiveSeconds對象處于緩存狀態的最多秒數,

          overflowtodisk內存不足時是否啟用磁盤緩存 -->  

            <diskStore path="java.io.tmpdir"/>  

            <defaultCache maxElementsInMemory="10000" eternal="false"  timeToIdleSeconds="300"            timeToLiveSeconds="600" overflowToDisk="true"/>

          </ehcache>

           

          3.最后要在映射文件***.hbm.xml中指定實體的緩存同步策略

          <?xml version="1.0" encoding='UTF-8'?>  

          <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 

          "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd" >  

          <hibernate-mapping>  

             <class>  

                 <!-- 設置該持久化類的二級緩存并發訪問策略-->  

                 <cache usage="read-write"/>

          <set name = "xxx">

          <cache usage="read-only" />

              </set>

             </class>

          </hibernate-mapping>  

           

          hibernate提供的緩存同步策略,可以在usage中設置

          read-only

          只讀

          nonstrict-read-write

          更新頻率不高

          read-write

          嚴格可讀寫

          transactional(Ecache不支持)

          事務型緩存

          posted on 2010-08-22 23:22 wkkyo 閱讀(449) 評論(0)  編輯  收藏 所屬分類: Hibernate

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 清镇市| 苏尼特右旗| 灵石县| 鲁甸县| 仁化县| 乌兰浩特市| 博罗县| 东乡族自治县| 徐闻县| 吴川市| 张家界市| 吉隆县| 云龙县| 淳化县| 霍城县| 安平县| 海原县| 右玉县| 南投市| 六盘水市| 佛山市| 昔阳县| 吴堡县| 无棣县| 甘肃省| 襄城县| 车致| 沈丘县| 锡林浩特市| 象山县| 黄陵县| 长春市| 延安市| 文化| 沛县| 松原市| 友谊县| 泰顺县| 白山市| 岱山县| 集安市|