Mybatis使用第三方缓存框架ehchache

Mybatis提供了很多与其他框架的整合解决方案:https://github.com/mybatis

ehcache缓存框架整合的文档地址:http://www.mybatis.org/ehcache-cache/

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缓存的配置文件解释: https://my.oschina.net/u/1450300/blog/525886

1、属性说明

2.1.diskStore

扫描二维码关注公众号,回复: 4180751 查看本文章

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

2.2.defaultCache

  默认缓存配置

2.3.cache

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

2.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)默认策略:

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

猜你喜欢

转载自blog.csdn.net/qq_42402854/article/details/84204478
今日推荐