文档章节

Ehcache使用的参数说明

风中帆
 风中帆
发布于 2015/11/04 17:06
字数 1181
阅读 867
收藏 16

【推荐】2019 Java 开发者跳槽指南.pdf(吐血整理) >>>

Ehcache使用的参数说明


1.ehcache.xml中参数说明

  ehcache.xml文件:

<?xml version="1.0" encoding="UTF-8"?>
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:noNamespaceSchemaLocation="http://ehcache.org/ehcache.xsd">
   
    <diskStore path="java.io.tmpdir/ehcache"/>
    
    <!-- 默认缓存 -->
    <defaultCache
           maxElementsInMemory="1000"
           eternal="false"
           timeToIdleSeconds="120"
           timeToLiveSeconds="120"
           overflowToDisk="false"/>
           
    <!-- 菜单缓存 -->       
    <cache name="menuCache" 
           maxElementsInMemory="1000" 
           eternal="false"
           timeToIdleSeconds="120"
           timeToLiveSeconds="120"
           overflowToDisk="false" 
           memoryStoreEvictionPolicy="LRU"/>
    
</ehcache>


参数说明:

<diskStore>:当内存缓存中对象数量超过maxElementsInMemory时,将缓存对象写到磁盘缓存中(需对象实现序列化接口)。

<diskStore path="">:用来配置磁盘缓存使用的物理路径,Ehcache磁盘缓存使用的文件后缀名是*.data和*.index。

name:缓存名称,cache的唯一标识(ehcache会把这个cache放到HashMap里)。

maxElementsOnDisk:磁盘缓存中最多可以存放的元素数量,0表示无穷大。

maxElementsInMemory:内存缓存中最多可以存放的元素数量,若放入Cache中的元素超过这个数值,则有以下两种情况。

1)若overflowToDisk=true,则会将Cache中多出的元素放入磁盘文件中。

2)若overflowToDisk=false,则根据memoryStoreEvictionPolicy策略替换Cache中原有的元素。

Eternal:缓存中对象是否永久有效,即是否永驻内存,true时将忽略timeToIdleSeconds和timeToLiveSeconds。

timeToIdleSeconds:缓存数据在失效前的允许闲置时间(单位:秒),仅当eternal=false时使用,默认值是0表示可闲置时间无穷大,此为可选属性即访问这个cache中元素的最大间隔时间,若超过这个时间没有访问此Cache中的某个元素,那么此元素将被从Cache中清除。

timeToLiveSeconds:缓存数据在失效前的允许存活时间(单位:秒),仅当eternal=false时使用,默认值是0表示可存活时间无穷大,即Cache中的某元素从创建到清楚的生存时间,也就是说从创建开始计时,当超过这个时间时,此元素将从Cache中清除。

overflowToDisk:内存不足时,是否启用磁盘缓存(即内存中对象数量达到maxElementsInMemory时,Ehcache会将对象写到磁盘中),会根据标签中path值查找对应的属性值,写入磁盘的文件会放在path文件夹下,文件的名称是cache的名称,后缀名是data。

diskPersistent:是否持久化磁盘缓存,当这个属性的值为true时,系统在初始化时会在磁盘中查找文件名为cache名称,后缀名为index的文件,这个文件中存放了已经持久化在磁盘中的cache的index,找到后会把cache加载到内存,要想把cache真正持久化到磁盘,写程序时注意执行net.sf.ehcache.Cache.put(Element element)后要调用flush()方法。

diskExpiryThreadIntervalSeconds:磁盘缓存的清理线程运行间隔,默认是120秒。

diskSpoolBufferSizeMB:设置DiskStore(磁盘缓存)的缓存区大小,默认是30MB

memoryStoreEvictionPolicy:内存存储与释放策略,即达到maxElementsInMemory限制时,Ehcache会根据指定策略清理内存,共有三种策略,分别为LRU(最近最少使用)、LFU(最常用的)、FIFO(先进先出)。



2.service层使用中的参数说明

   2.1     添加缓存

@Cacheable(value="menuCache",key="'UserMenuKey'+#userid")
    public List<MenuBean> queryMenuByUserId(String userid)
{
……
}


@Cacheable主要针对方法配置,能够根据方法的请求参数对其结果进行缓存。


@CachePut主要针对方法配置,能够根据方法的请求参数对其结果进行缓存,和 @Cacheable 不同的是,它每次都会触发真实方法的调用。


   2.2     清除缓存

@CacheEvict(value="menuCache",key="'UserMenuKey'+#userRoleBean.getUserId()")
public boolean delUserRole(UserRoleBean userRoleBean) {
……
}

 

@CachEvict主要针对方法配置,能够根据一定的条件对缓存进行清空。

 


3.ehcache将缓存内容存入硬盘

<diskStore path="C:/temp"/>

<cache name="authCache1"
           maxElementsInMemory="36"
           maxElementsOnDisk="10000"
           overflowToDisk="true"

           diskPersistent="true"
           diskSpoolBufferSizeMB="20"
            />

当内存中的数据量超过了设置的最大记录数maxElementsInMemory,则会将多余的记录数存入硬盘,但是内存中已经存在的内容则不会自动存入硬盘,需要手动使用cache.flush()来强制将内存内容放入硬盘中;

一般maxElementsOnDisk的值需要设置的比maxElementsInMemory大,这样效率会高一些;

需要设置overflowToDisk为true,表示使用硬盘缓存策略;

需要设置diskPersistent为true,否则重启服务后缓存文件会被清理掉,同时该属性会在一定程度上拖慢缓存速度,因为它需要不停地监控设置的硬盘大小是否已满关联属性为diskSpoolBufferSizeMB,如果硬盘够大可以将该属性设置足够大;

最后 会生成*.index和*.data2个文件;


*重建缓存会自动从硬盘读取数据到内存


本文转载自:http://blog.csdn.net/clj198606061111/article/details/41121437

风中帆
粉丝 14
博文 200
码字总数 18552
作品 0
青岛
私信 提问
ehcache整合spring注解方式

一、简介   在hibernate中就是用到了ehcache 充当缓存。spring对ehcache也提供了支持,使用也比较简单,只需在spring的配置文件中将ehcache的ehcache.xml文件配置进去即可。在spring中使用...

烟火_
2014/11/23
0
0
mybatis缓存的使用及理解

和hibernate一样,mybatis也有缓存机制 一级缓存是基于 PerpetualCache(mybatis自带)的 HashMap 本地缓存,作用范围为session,所以当session commit或close后,缓存就会被清空 二级缓存默认也是...

whaon
2013/04/16
27.2K
0
【EhCache】Java缓存框架使用EhCache结合Spring AOP

一.Ehcache简介 EhCache是一个纯Java的进程内缓存框架,具有如下特点: 1. 快速简单,非常容易和应用集成。 2.支持多种缓存策略 。 3. 缓存数据有两级:内存和磁盘,因此无需担心容量问题 。...

磊神Ray
2012/08/07
2.2K
7
Mybatis缓存机制理解及配置

Ehcache EHCache是来自sourceforge(http://ehcache.sourceforge.net/)的开源项目,也是纯Java实现的简单、快速的Cache组件。EHCache支持内存和磁盘的缓存,支持LRU、LFU和FIFO多种淘汰算法...

Panshuyang
2016/02/23
302
0
BigMemroy系列文章--6. Ehcache扩展功能--Jmx、同步

转载请注明出处哈:http://carlosfu.iteye.com/blog/2237511 一、使用JMX监控和管理Ehcache ehcache-core.jar中的net.sf.ehcache.management包提供了基于JMX标准的MBeans和ManagementService...

付磊-起扬
2015/08/24
0
0

没有更多内容

加载失败,请刷新页面

加载更多

一篇文章教你轻松使用fastjson

前言 只有光头才能变强。 文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y JSON相信大家对他也不陌生了,前后端交互中常常就以JSON来进行数据交换。而有的...

Java3y
28分钟前
4
1
分组功能(tapply,by,aggregate)和* apply系列

每当我想在R中做“ map” py任务时,我通常都会尝试在apply系列中使用一个函数。 但是,我从未完全理解它们之间的区别-{ sapply , lapply等}如何将函数应用于输入/分组输入,输出将是什么样...

javail
28分钟前
4
0
PHP环境搭建之单独安装

还在使用PHP集成环境吗?教你自定义搭建配置PHP开发环境,按照需求进行安装,安装的版本可以自己选择,灵活性更大。 目录: 1. 安装Apache 2. 安装PHP 3. 安装MySQL 4. 安装Composer 观看:h...

不冷的大叔
40分钟前
4
0
为什么JavaScript变量会以美元符号开头?

我经常看到JavaScript带有以美元符号开头的变量。 您何时/为什么选择以这种方式为变量添加前缀? (我不是在问您在jQuery和其他语言中看到的$('p.foo')语法,而是普通变量,例如$name和$orde...

技术盛宴
44分钟前
4
0
TCP 三次握手

https://my.oschina.net/u/4198159/blog/3141874

奋斗的小牛
53分钟前
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部