关于mybatis缓存

3 篇文章 0 订阅
1 篇文章 0 订阅

1.mybatis为什么需要缓存了??

拉高程序的性能

2. 什么样的数据需要缓存

很少被修改或根本不改的数据
业务场景比如:耗时较高的统计分析sql、电话账单查询sql等

3. ehcache是什么

Ehcache 是现在最流行的纯Java开源缓存框架,配置简单、结构清晰、功能强大

注1:本次介绍的是2.X版本,3.x的版本和2.x的版本API差异比较大

4. ehcache的特点

4.1 够快

  • Ehcache的发行有一段时长了,经过几年的努力和不计其数的性能测试,Ehcache终被设计于large, high
    concurrency systems.

4.2 够简单

  • 开发者提供的接口非常简单明了,从Ehcache的搭建到运用运行仅仅需要的是你宝贵的几分钟。其实很多开发者都不知道自己用在用Ehcache,Ehcache被广泛的运用于其他的开源项目

4.3 够袖珍

  • 关于这点的特性,官方给了一个很可爱的名字small foot print ,一般Ehcache的发布版本不会到2M,V 2.2.3 才
    668KB。

4.4 够轻量

  • 核心程序仅仅依赖slf4j这一个包,没有之一!

4.5 好扩展

  • Ehcache提供了对大数据的内存和硬盘的存储,最近版本允许多实例、保存对象高灵活性、提供LRU、LFU、FIFO淘汰算法,基础属性支持热配置、支持的插件多

4.6 监听器

  • 缓存管理器监听器 (CacheManagerListener)和
    缓存监听器(CacheEvenListener),做一些统计或数据一致性广播挺好用的

4.7 分布式缓存

  • 从Ehcache 1.2开始,支持高性能的分布式缓存,兼具灵活性和扩展性

5. ehcache的使用

5.1 导入相关依赖

<dependency>
   <groupId>net.sf.ehcache</groupId>
   <artifactId>ehcache</artifactId>
   <version>2.10.0</version>
</dependency>

5.2 核心接口
CacheManager:缓存管理器
Cache:缓存对象,缓存管理器内可以放置若干cache,存放数据的实质,所有cache都实现了Ehcache接口
Element:单条缓存数据的组成单位

5.3 src:ehcache.xml

6. ssm中整合ehcache

6.1 导入相关依赖

	<!--7)spring对ehcache的相关支持-->
	<dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context-support</artifactId>
            <version>${spring.version}</version>
     </dependency>

    	<!--4) mybatis与ehcache整合 -->
    <dependency>
         <groupId>org.mybatis.caches</groupId>
         <artifactId>mybatis-ehcache</artifactId>
         <version>1.1.0</version>
     </dependency>

      <!-- ********************** ehcache依赖 ********************** -->
   	<dependency>
   		<groupId>net.sf.ehcache</groupId>
     	<artifactId>ehcache</artifactId>
     	<version>2.10.0</version>
   	</dependency>

6.2 修改日志配置,因为ehcache使用了Slf4j作为日志输出

  • 日志我们使用slf4j,并用log4j来实现。SLF4J不同于其他日志类库,与其它有很大的不同。
    SLF4J(Simple logging Facade for Java)不是一个真正的日志实现,而是一个抽象层( abstraction layer),
    它允许你在后台使用任意一个日志类库。

      详情见“Log4j2 + Slf4j.pom.txt”
    

6.3 在Resource中添加一个ehcache.xml的配置文件

6.4 在spring.xml中加入chache配置

  <!-- 使用ehcache缓存 -->
    <bean id="cacheManagerFactory" class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean">
        <property name="configLocation" value="classpath:ehcache.xml"/>
        <property name="shared" value="true"></property>
    </bean>
    <!-- 默认是cacheManager -->
    <bean id="cacheManager" class="org.springframework.cache.ehcache.EhCacheCacheManager">
        <property name="cacheManager" ref="cacheManagerFactory"/>
    </bean>

6.5 mybaits的二级缓存是mapper范围级别,除了在SqlMapConfig.xml设置二级缓存的总开关,还要在具体的mapper.xml中开启二级缓存

  • 6.5.1 开启mybatis的二级缓存

       <settings>
         <setting name="logImpl" value="SLF4J"/>
         <!-- 开启二级缓存 -->
         <setting name="cacheEnabled" value="true"/>
       </settings>
    
  • 6.5.2 在XxxMapper.xml中配置cache

       <!-- 以下两个<cache>标签二选一,第一个可以输出日志,第二个不输出日志 -->
       <!--<cache type="org.mybatis.caches.ehcache.LoggingEhcache" />-->
       <!--<cache type="org.mybatis.caches.ehcache.EhcacheCache" />-->
       <!--eviction="FIFO"  回收策略为先进先出-->
       <!--flushInterval="60000" 自动刷新时间60s-->
       <!--size="512" 最多缓存512个引用对象-->
       <!--readOnly="true"  只读-->
       <cache type="org.mybatis.caches.ehcache.EhcacheCache">
         <property name="timeToIdleSeconds" value="3600"/>
         <property name="timeToLiveSeconds" value="3600"/>
         <property name="maxEntriesLocalHeap" value="1000"/>
         <property name="maxEntriesLocalDisk" value="10000000"/>
         <property name="memoryStoreEvictionPolicy" value="LRU"/>
       </cache>
    
  • 6.5/3 可以通过select标签的useCache属性打开或关闭二级缓存

     <select id="selectByPrimaryKey" resultMap="BaseResultMap" parameterType="java.lang.Long" useCache="false"></select>
    

7. 小结
  对于访问多的查询请求且用户对查询结果实时性要求不高,此时可采用mybatis二级缓存技术降低数据库访问量,提高访问速度,
实现方法如下:通过设置刷新间隔时间,由mybatis每隔一段时间自动清空缓存,根据数据变化频率设置缓存刷新间隔flushInterval,比如设置为30分钟、60分钟、24小时等,根据需求而定。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值