ecache的简单配置使用

Ehcache 与 spring 整合后的用法,下面是一个Ehcache.xml配置文件;

通用的缓存策略 可以用一个 cache;

复制代码
 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 3          xsi:noNamespaceSchemaLocation="http://ehcache.org/ehcache.xsd"
 4          updateCheck="false">
 5 
 6     <!--
 7     diskStore:为缓存路径,ehcache分为内存和磁盘 2级,此属性定义磁盘的缓存位置
 8     user.home - 用户主目录
 9     user.dir - 用户当前工作目录
10     java.io.tmpdir - 默认临时文件路径
11     -->
12 <diskStore path="java.io.tmpdir/Tmp_Ehcache" />
13     <!--
14       name:缓存名称。
15       maxElementsInMemory:缓存最大数目
16       maxElementsOnDisk:硬盘最大缓存个数。
17       eternal:对象是否永久有效,一但设置了,timeout将不起作用。
18       overflowToDisk:是否保存到磁盘,当系统当机时
19       timeToIdleSeconds:设置对象在失效前的允许闲置时间(单位:秒)。仅当eternal=false对象不是永久有效时使用,可选属性,默认值是0,也就是可闲置时间无穷大。
20       timeToLiveSeconds:设置对象在失效前允许存活时间(单位:秒)。最大时间介于创建时间和失效时间之间。仅当eternal=false对象不是永久有效时使用,默认是0.,也就是对象存活时间无穷大。
21       diskPersistent:是否缓存虚拟机重启期数据 Whether the disk store persists between restarts of the Virtual Machine. The default value is false.
22       diskSpoolBufferSizeMB:这个参数设置DiskStore(磁盘缓存)的缓存区大小。默认是30MB。每个Cache都应该有自己的一个缓冲区。
23       diskExpiryThreadIntervalSeconds:磁盘失效线程运行时间间隔,默认是120秒。
24       memoryStoreEvictionPolicy:当达到maxElementsInMemory限制时,Ehcache将会根据指定的策略去清理内存。默认策略是LRU(最近最少使用)。你可以设置为FIFO(先进先出)或是LFU(较少使用)。
25        clearOnFlush:内存数量最大时是否清除。
26         memoryStoreEvictionPolicy:可选策略有:LRU(最近最少使用,默认策略)、FIFO(先进先出)、LFU(最少访问次数)。
27            FIFO,first in first out,这个是大家最熟的,先进先出。
28            LFU, Less Frequently Used,就是上面例子中使用的策略,直白一点就是讲一直以来最少被使用的。如上面所讲,缓存的元素有一个hit属性,hit值最小的将会被清出缓存。
29            LRU,Least Recently Used,最近最少使用的,缓存的元素有一个时间戳,当缓存容量满了,而又需要腾出地方来缓存新的元素的时候,那么现有缓存元素中时间戳离当前时间最远的元素将被清出缓存。
30    -->
31 <defaultCache
32         eternal="false"
33         maxElementsInMemory="1000"
34         overflowToDisk="false"
35         diskPersistent="false"
36         timeToIdleSeconds="0"
37         timeToLiveSeconds="600"
38         memoryStoreEvictionPolicy="LRU"
39 />
40     <cache
41             name="demo"
42             eternal="false"
43             maxElementsInMemory="100"
44             overflowToDisk="false"
45             diskPersistent="false"
46             timeToIdleSeconds="0"
47             timeToLiveSeconds="300"
48             memoryStoreEvictionPolicy="LRU"
49     />
50 
51 </ehcache>
复制代码

其实缓存无非就是减少数据库的查询操作,接下来简单说下在 代码中的使用方法,

先把ehcache 配置到 spring中(下面是使用spring-boot)

复制代码
package com.config;

import org.springframework.cache.annotation.EnableCaching;
import org.springframework.cache.ehcache.EhCacheCacheManager;
import org.springframework.cache.ehcache.EhCacheManagerFactoryBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.io.ClassPathResource;

import javax.persistence.Cache;

/**
 * Created by ding on 2017-04-25.
 */
@Configuration
@EnableCaching//标记启动缓存
public class CacheConfiguration {
    //ehcache 主要的管理器 EhcacheManager

    @Bean
    public EhCacheManagerFactoryBean ehCacheManagerFactoryBean(){
        EhCacheManagerFactoryBean factoryBean=new EhCacheManagerFactoryBean();
        factoryBean.setConfigLocation(new ClassPathResource("ehcache.xml"));
        factoryBean.setShared(true);//也说是说通过这个来设置cache的基地是这里的Spring独用,还是跟别的(如hibernate的Ehcache共享)
        return factoryBean;
    }

    @Bean
    public EhCacheCacheManager ehCacheCacheManager(EhCacheManagerFactoryBean factoryBean){
        System.out.println("CacheConfiguration.ehcacheManager()");
        return new EhCacheCacheManager(factoryBean.getObject());

    }


}
复制代码

 

留意下java代码@cacheAble 注解中的 value 对应 ehcache.xml中定义的cache的name属性(没有找到,就会用默认的配置)

@cacheAble 注解中的 key 就是缓存的key,调用方法的时候,就是根据这个key是否存在缓存中 从而决定是否进入方法

注意:@cacheable注解只能用在实现类中,不能再接口中使用!!!

复制代码
@Service
public class InfoServiceImpl {

   //value属性表示使用哪个缓存策略,缓存策略在ehcache.xml中
    //LRU(最近最少使用,默认策略)、FIFO(先进先出)、LFU(最少访问次数)
    public static final String DEMO_CACHE_NAME = "demo";//这个demo和ehcache中的 name对应

    //所有key 中的单引号 都不能少,不然会被识别成一个对象
    @Cacheable(value = DEMO_CACHE_NAME, key = "'info_'+#id")
    public String findNameById(Integer id) {
        //Cacheable 不存在这个key 才会进入方法
        System.out.println("没有走缓存:" + id);
        return "zhangsan";
    }

    @CacheEvict(value = DEMO_CACHE_NAME, key = "'info_'+#id")//清除缓存:是根据这个key来清理的,没有找到key对应的缓存就没清理了public void delete(Integer id) {
        //数据库删除操作……(略)
    }

    
    @CachePut(value = DEMO_CACHE_NAME, key = "'info_'+#infos.getId()")
    public String update(String str) {
        /*
        @cachePut 表示重新放入缓存对象,不管是否存在这个key的缓存,所以一定会进入方法
        */
        return str;
    }

   
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
本实例的环境 eclipse + maven + spring + ehcache + junit EhCache 是一个纯Java的进程内缓存框架,具有快速、精干等特点,是Hibernate中默认的CacheProvider。Ehcache是一种广泛使用的开 源Java分布式缓存。主要面向通用缓存,Java EE和轻量级容器。它具有内存和磁盘存储,缓存加载器,缓存扩展,缓存异常处理程序,一个gzip缓存servlet过滤器,支持REST和SOAP api等特点。 优点: 1. 快速 2. 简单 3. 多种缓存策略 4. 缓存数据有两级:内存和磁盘,因此无需担心容量问题 5. 缓存数据会在虚拟机重启的过程中写入磁盘 6. 可以通过RMI、可插入API等方式进行分布式缓存 7. 具有缓存和缓存管理器的侦听接口 8. 支持多缓存管理器实例,以及一个实例的多个缓存区域 9. 提供Hibernate的缓存实现 缺点: 1. 使用磁盘Cache的时候非常占用磁盘空间:这是因为DiskCache的算法简单,该算法简单也导致Cache的效率非常高。它只是对元素直接追加存储。因此搜索元素的时候非常的快。如果使用DiskCache的,在很频繁的应用中,很快磁盘会满。 2. 不能保证数据的安全:当突然kill掉java的时候,可能会产生冲突,EhCache的解决方法是如果文件冲突了,则重建cache。这对于Cache 数据需要保存的时候可能不利。当然,Cache只是简单的加速,而不能保证数据的安全。如果想保证数据的存储安全,可以使用Bekeley DB Java Edition版本。这是个嵌入式数据库。可以确保存储安全和空间的利用率。 EhCache的分布式缓存有传统的RMI,1.5版的JGroups,1.6版的JMS。分布式缓存主要解决集群环境中不同的服务器间的数据的同步问题。 使用Spring的AOP进行整合,可以灵活的对方法的返回结果对象进行缓存

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值