<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-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 閱讀(446) 評論(0)  編輯  收藏 所屬分類: Hibernate

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


    網站導航:
     
    主站蜘蛛池模板: 久久久久国色AV免费观看性色| 成人一区二区免费视频| 97在线视频免费播放| 亚洲高清视频在线观看| 女人体1963午夜免费视频| 久久91亚洲精品中文字幕| 久久精品免费视频观看| 综合自拍亚洲综合图不卡区| 91高清免费国产自产拍2021| 亚洲成人在线免费观看| 无码视频免费一区二三区| 久久水蜜桃亚洲AV无码精品| 免费a级毛片大学生免费观看 | 国产精品亚洲mnbav网站 | 亚洲国产成人精品女人久久久 | 亚洲一区免费观看| 免费国产不卡午夜福在线| 色网站在线免费观看| 中文字幕亚洲日本岛国片| 亚洲一级毛片在线播放| 99久久免费精品国产72精品九九| 亚洲AV成人影视在线观看| 国产一区二区三区免费视频| 又黄又大的激情视频在线观看免费视频社区在线 | 亚洲狠狠婷婷综合久久久久| 中文字幕无码亚洲欧洲日韩| 野花高清在线电影观看免费视频| 亚洲精品无码av中文字幕| 免费一级肉体全黄毛片| a毛片免费观看完整| 亚洲性一级理论片在线观看| 四虎免费在线观看| 本道天堂成在人线av无码免费 | 亚洲熟妇无码一区二区三区导航| 日韩在线天堂免费观看| 亚洲午夜精品在线| 四虎永久免费观看| 99久热只有精品视频免费观看17| 亚洲色欲一区二区三区在线观看| 91短视频在线免费观看| 精品久久久久久亚洲综合网|