您的当前位置:首页正文

Mybatis使用第三方缓存框架EhCache

2024-11-05 来源:个人技术集锦

Mybatis提供了很多与其他框架的整合解决方案:

EhCache是一种广泛使用的开源Java分布式缓存,具有快速、简单、多种缓存策略,缓存数据有内存和硬盘的特点。

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

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

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

2、在sql映射文件中的mapper标签下配置开启ehcace缓存

<mapper namespace="cn.jq.mybatis.dao.UserMapper">
	<cache type="org.mybatis.caches.ehcache.EhcacheCache"/>

3、写一个ehcache缓存的配置文件ehcache.xml

<?xml version="1.0" encoding="UTF-8" ?>
<ehcache>   
    <diskStore path="d:/ehcache/"/>     
    <defaultCache     
           maxElementsInMemory="10000"    
           eternal="false"    
           timeToIdleSeconds="120"    
           timeToLiveSeconds="120"    
           overflowToDisk="true"    
           maxElementsOnDisk="10000000"    
           diskPersistent="false"    
           diskExpiryThreadIntervalSeconds="120"    
           memoryStoreEvictionPolicy="LRU"    
           />     
</ehcache>

  运行实例即可

 

EhCache缓存的配置文件解释: 

1.diskStore

  指定数据存储位置,可指定磁盘中的文件夹位置。样例中配置位置为“d:/ehcache/”, 什么意思呢? 内存中的缓存满了,装不下了,就放这里,注意:它是临时的文件, sessionFactory.close后, 这里的文件会自动删除!

2.defaultCache   默认缓存配置

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

4.配置属性中的元素说明

   1)maxElementsInMemory(正整数):在内存中缓存的最大对象数量

   2)maxElementsOnDisk(正整数):在磁盘上缓存的最大对象数量,默认值为0,表示不限制。

   3)eternal:

    设定缓存对象保存的永久属性,默认为 false 。当为 true 时 timeToIdleSeconds、timeToLiveSeconds 失效。 表示这个缓存永远不清除!

   4)timeToIdleSeconds(单位:秒):

    对象空闲时间,指对象在多长时间没有被访问就会失效。只对eternal为false的有效。默认值0,表示一直可以访问。失效时间!

   5)timeToLiveSeconds(单位:秒):

    对象存活时间,指对象从创建到失效所需要的时间。只对eternal为false的有效。默认值0,表示一直可以访问。

   6)overflowToDisk:如果内存中数据超过内存限制,是否要缓存到磁盘上。

     7)diskPersistent:是否在磁盘上持久化。指重启jvm后,数据是否有效。默认为false。

     8)diskSpoolBufferSizeMB(单位:MB):DiskStore使用的磁盘大小,默认值30MB。每个cache使用各自的DiskStore。

    9)memoryStoreEvictionPolicy:如果内存中数据超过内存限制,向磁盘缓存时的策略。默认值LRU,可选FIFO、LFU。

        10) diskExpiryThreadIntervalSeconds :  清理线程执行清理的间隔时间。

 

2、清空策略

    1)FIFO(first in first out):先进先出

    2)LFU(Less Frequently Used): 最少被使用,缓存的元素有一个hit属性,hit值最小的将会被清除缓存。

    3)LRU(Least Recently Used)默认策略:

  最近最少使用,缓存的元素有一个时间戳,当缓存容量满了,而又需要腾出地方来缓存新的元素的时候,那么现有缓存元素中时间戳离当前时间最远的元素将被清除缓存。

 

ends~

 

Top