ehcache简单配置
<?xml version="1.0" encoding="UTF-8"?>
<ehcache dynamicConfig="true">
<!-- 磁盘缓存位置 -->
<diskStore path="/files/cache"/>
<!-- 反向代理缓存 -->
<!--maxBytesLocalDisk缓存所能使用的磁盘的最大字节数的,其单位可以是K、M或G。默认是0,表示不限制。只有在单机环境下才可以使用本地磁盘-->
<!--timeToLiveSeconds:对象存活时间,指对象从创建到失效所需要的时间。只对eternal为false的有效。默认值为0,表示一直可以访问。(单位:秒)-->
<!--timeToIdleSeconds:对象空闲时,指对象在多长时间没有被访问就会失效。只对eternal为false的有效。默认值为0。(单位:秒)-->
<!--eternal如果为true,则缓存的数据始终有效-->
<!--diskSpoolBufferSizeMB(磁盘缓存)的缓存区大小。默认是30MB-->
<!--overflowToDisk如果内存中数据超过内存限制,是否要缓存到磁盘上-->
<!--diskPersistent是否在磁盘上持久化。指重启JVM后,数据是否有效-->
<!--memoryStoreEvictionPolicy如果内存中数据超过内存限制,向磁盘缓存定时的策略,默认值为LRU-->
<cache name="scorpiocache"
maxBytesLocalDisk="500M"
maxBytesLocalHeap="100M"
timeToIdleSeconds="0"
timeToLiveSeconds="0"
eternal="true"
diskSpoolBufferSizeMB="100"
overflowToDisk="true"
diskPersistent="true"
memoryStoreEvictionPolicy="LRU"/>
timeToLiveSeconds和timeToIdleSeconds比较:(只有在eternal为false时,这2个属性才有效)
现在假设有如下配置:
timeToIdleSeconds=60
timeToLiveSeconds=180
则一个数据被添加进缓存后,该数据能够在缓存中存活的最长时间为180秒(timeToLiveSeconds),而在180秒内,假设不止一次去缓存中拿取该数据,那么相邻2次获取数据的时间间隔如果小于60秒(timeToIdleSeconds),则能成功获取到数据,但如果最近一次获取到下一次获取的时间间隔超过60秒,那么,将得到null,因为此时该数据已经被移出缓存了。
而且,timeToLiveSeconds必须大于timeToIdleSeconds才有意义。

浙公网安备 33010602011771号