美文网首页
MyBatis进阶-Ehcache实现缓存

MyBatis进阶-Ehcache实现缓存

作者: Super超人 | 来源:发表于2018-11-15 16:08 被阅读18次

    最近在探寻 MyBatis持久层框架,发现入门简单,但是随着满足各种需求的增加,MyBatis的功能也让人眼花缭乱。今天写笔记来记录下一个第三方缓存框架 Ehcache 和 MyBatis的简单配合使用,来实现数据缓存。

    一、Ehcache简介

    Ehcache 是一种广泛使用的开源 Java 分布式缓存。具有快速简单低消耗依赖性小扩展性强支持对象或序列化缓存支持缓存或元素的失效提供 LRU / LFU / FIFO 缓存策略支持内存缓存和磁盘缓存分布式缓存机制等等特点。
      Ehcache 作为开放源代码项目,采用限制比较宽松的Apache License V2.0作为授权方式,被广泛地用于Hibernate、Spring、Cocoon等其他开源系统。Ehcache 从 Hibernate 发展而来,逐渐涵盖了 Cahce 界的全部功能,是目前发展势头最好的一个项目。

    MyBatis 和 Ehcache 整合框架下载地址:
    https://github.com/mybatis/ehcache-cache
    Ehcache缓存框架整合的文档地址:
    http://www.mybatis.org/ehcache-cache/

    二、Ehcache 文件配置

    1. Maven 工程配置 pom.xml导入 jar 包

    MyBatis 和 Ehcache 整合架包

    <dependency>
        <groupId>org.mybatis.caches</groupId>
        <artifactId>mybatis-ehcache</artifactId>
        <version>1.1.0</version>
    </dependency>
    

    因为 Ehcache 的依赖 slf4j 这个日志的 jar 包,会和 log4j 的 jar 包冲突,导致日志不能显示了,解决办法就整合他们,导入联合jar包,所以还要一个依赖

    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-log4j12</artifactId>
        <version>1.7.25</version>
        <scope>test</scope>
    </dependency>
    
    2. 配置步骤

    ① 创建 ehcache.xml 文件

    <?xml version="1.0" encoding="UTF-8"?>
    <ehcache>
        <!-- mac 电脑, 跟 win 设置路径有点不一样 示例: path="d:/ehcache/" -->
        <diskStore path="${user.home}/Downloads/ehcache" />
        
        <!-- 默认缓存配置 没有特别指定就用这个配置 -->
        <defaultCache maxElementsInMemory="10000" 
                      eternal="false"
                      timeToIdleSeconds="3600" <!--1 hour-->
                      timeToLiveSeconds="3600" <!--1 hour-->
                      overflowToDisk="true"
                      maxElementsOnDisk="10000000" 
                      diskPersistent="false"
                      memoryStoreEvictionPolicy="LRU" 
                      diskExpiryThreadIntervalSeconds="120" />
    </ehcache>
    

    ② 在 MyBatis 配置文件中开启二级缓存配置

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

    ③ 在 Mapper 配置文件中开启缓存,添加 Ehcache 缓存

    <mapper namespace="com.ogemray.dao.StudentDao">
      <cache type="org.mybatis.caches.ehcache.EhcacheCache"/>
      ...
    </mapper>
    

    ④ 缓存实体类要实现 Serializable 接口

    public class Student implements Serializable
    
    3. Ehcache 配置标签和属性说明
    • diskStore:指定数据存储位置,可指定磁盘中的文件夹位置。样例中配置位置为“d:/ehcache/”, 什么意思呢? 内存中的缓存满了,装不下了,就放这里,注意:它是临时的文件, sessionFactory.close后, 这里的文件会自动删除!

    • defaultCache:默认缓存配置

    • cache:指定对象的缓存配置,其中 name 属性为指定缓存的名称(必须唯一)

    • 配置属性中的元素说明
      maxElementsInMemory (正整数):在内存中缓存的最大对象数量
      maxElementsOnDisk (正整数):在磁盘上缓存的最大对象数量,默认值为0,表示不限制。
      eternal:设定缓存对象保存的永久属性,默认为 false 。当为 true 时 timeToIdleSeconds、timeToLiveSeconds 失效。 表示这个缓存永远不清除!
      timeToIdleSeconds (单位:秒):对象空闲时间,指对象在多长时间没有被访问就会失效。只对eternal为false的有效。默认值0,表示一直可以访问。失效时间!
      timeToLiveSeconds (单位:秒):对象存活时间,指对象从创建到失效所需要的时间。只对eternal为false的有效。默认值0,表示一直可以访问。
      overflowToDisk:如果内存中数据超过内存限制,是否要缓存到磁盘上。
      diskPersistent:是否在磁盘上持久化。指重启jvm后,数据是否有效。默认为false。
      diskSpoolBufferSizeMB (单位:MB):DiskStore使用的磁盘大小,默认值30MB。每个cache使用各自的DiskStore。
      diskExpiryThreadIntervalSeconds:清理线程执行清理的间隔时间。
      memoryStoreEvictionPolicy:如果内存中数据超过内存限制,向磁盘缓存时的策略。默认值LRU,可选FIFO、LFU。

      • FIFO (first in first out):先进先出
      • LFU (Less Frequently Used):最少被使用,缓存的元素有一个hit属性,hit值最小的将会被清除缓存。
      • LRU (Least Recently Used) 默认策略:最近最少使用,缓存的元素有一个时间戳,当缓存容量满了,而又需要腾出地方来缓存新的元素的时候,那么现有缓存元素中时间戳离当前时间最远的元素将被清除缓存。

    相关文章

      网友评论

          本文标题:MyBatis进阶-Ehcache实现缓存

          本文链接:https://www.haomeiwen.com/subject/vbsgtqtx.html