mybatis 緩存

mybatis 緩存

數據模型分析思路

  1. 每張表記錄的數據內容: 分模塊對每張表的內容進行熟悉,相當於學習系統需求功能的過程
  2. 每張表的重要字段: 非空字段、外鍵字段
  3. 數據庫表與表之間的關係: 外鍵字段
  4. 表與表之間的業務關係:建立在某個業務基礎之上去分析

mybatis 緩存

mybatis提供查詢緩存,用於減輕數據壓力,提高數據庫性能
mybaits提供一級緩存,和二級緩存

爲什麼要用緩存?
如果緩存中有數據就不用從數據庫中獲取,直接從緩存中獲取,大大提高系統性能

  1. 一級緩存:是sqlSession級別的緩存,在操作數據庫時需要構造 sqlSession對象,在對象中有一個數據結構(HashMap)用於存儲緩存數據,不同的sqlSession之間的緩存數據區域(HashMap)是互相不影響的

  2. 是mapper級別(命名空間)的緩存,多個SqlSession去操作同一個Mapper的sql語句,多個SqlSession可以共用二級緩存,二級緩存是跨SqlSession的。 即 同一個命名空間 namspace 下,開闢一個緩存區域,放置該mapper對應的查詢緩存數據,即使不同的sqlSession來調用,也可以訪問緩存。

注意: 每一個namespace的mapper都有一個二緩存區域,兩個mapper的namespace如果相同,這兩個mapper執行sql查詢到數據將存在相同 的二級緩存區域中

mybatis 緩存

一級緩存查詢原理

一級緩存查詢原理

當修改、刪除、添加用戶執行commit 時,就會清空一級緩存, 另外因爲一級緩存是跟隨sqlSession的,一旦sqlSession關閉,則緩存也會被清除,

正式開發,是將mybatis和spring進行整合開發,事務控制在service中。
一個service方法中包括 很多mapper方法調用。

service{
//開始執行時,開啓事務,創建SqlSession對象
//第一次調用mapper的方法findUserById(1)

//第二次調用mapper的方法findUserById(1),從一級緩存中取數據
//方法結束,sqlSession關閉

}

如果是執行兩次service調用查詢相同 的用戶信息,不走一級緩存,因爲session方法結束,sqlSession就關閉,一級緩存就清空。

二級緩存查詢原理

二級緩存查詢原理

二級緩存的應用場景
對於 訪問多的查詢請求且用戶對於查詢結果的實時性要求不高,此時可以採用mybatis 二級緩存來降低數據庫的訪問量,提高訪問速度,業務場景包括 耗時較高的統計分析sql賬單查詢

實現方法如下:通過設置刷新間隔時間,由mybatis每隔一段時間自動清空緩存,根據數據變化頻率設置緩存刷新間隔flushInterval,比如設置爲30分鐘、60分鐘、24小時等,根據需求而定。

mybatis 二級緩存的侷限

mybatis二級緩存對細粒度的數據級別的緩存實現不好, 比如對於商品信息進行緩存,由於商品信息查詢訪問量大,但是要求用戶每次都能查詢最新的商品信息,此時如果使用mybatis的 二級緩存就無法實現當一個商品變化時只刷新該商品的緩存信息而不刷新其它商品的信息(一個商品信息變化,二級緩存會將所有商品的信息從緩存中清除,非常不友好),因爲mybaits的二級緩存區域以mapper爲單位劃分,當一個商品信息變化會將所有商品信息的緩存數據全部清空。解決此類問題需要在業務層根據需求對數據有針對性緩存。

開啓二級緩存
- 默認情況下mybatis開啓的是一級緩存,即是sqlSession級別的緩存
- 開啓二級緩存分兩步:
第一: 在SqlMapConfig.xml設置二級緩存的總開關

<setting name="cacheEnabled" value="true"/>  

第二:在具體的mapper.xml中開啓二級緩存.

<mapper namspace = "com.dustin.ssm.mapper">
     <!-- 開啓二級緩存-->
    <cache/>
</mapper>

另外需要注意的是,因爲二級緩存在內存中的存儲介質多種多樣,爲了將緩存數據取出執行反序列化操作,需要將類實現序列化接口

如果開啓了二級緩存,但是其中的一條sql語句每次都要查詢最新數據怎麼辦? 不怕,mybatis 提供了useCache配置,可以針對某一條sql語句,禁用二級緩存功能

在statement中設置useCache=false可以禁用當前select語句的二級緩存,即每次查詢都會發出sql去查詢,默認情況是true,即該sql使用二級緩存

<select id="findOrderListResultMap" resultMap="ordersUserMap" useCache="false">

總結:針對每次查詢都需要最新的數據sql,要設置成useCache=false,禁用二級緩存。

mybatis 的緩存與其他分佈式緩存框架整合(ehcache,redis,mongdb)

mybatis 對緩存的支持並不是很好,因爲,mybatis並不是專門做緩存的,而是一個ORM框架

  • 爲什麼需要分佈式緩存服務
    目前的系統爲了提高併發性能,一般都對其做了分佈式的部署,應用運行在一個服務器集羣上面,那麼如果不使用分佈式緩存框架的話,那麼緩存分別就是保存在自己的那臺機器上面,不方便系統進行開發。
    舉個例子: 用戶登錄了系統,該請求分配到機器A登錄,那麼用戶的登錄信息緩存在機器A上面,如果下一次用戶發起了一個請求,被分到了機器B上,但是B上並沒有用戶的登錄信息,那麼用戶就需要再次登錄一遍,這是極其不合理的,所以需要針對緩存進行集中管理。

如何與其他分佈式框架整合

mybatis提供了一個cache接口,如果要實現自己的緩存邏輯,實現cache接口開發即可。

比如mybatis和ehcache整合,其他的也都是大同小異
1. 加入ehcache jar包
2. 配置mapper中cache中的type爲ehcache對cache接口的實現類型。

<mapper namespace="cn.itcast.ssm.mapper.UserMapper">
    <!-- 開啓mapper下的二級緩存,
    type: 指定cache接口的實現類型,與誰整合就配置誰的接口, 例如與ehcache整合需要配置type 爲ehcache實現的cache接口的類型
    -->
    <cache type = org.mybatis.caches.ehcache.EhcacheCache"/>
</mapper>

3 在classpath下加入ehcache的配置文件 ehcache.xml

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章