springboot和ehcache整合实例

1、maven中引入ehcache
springboot版本:1.4.1.RELEASE
ehcache:

<dependency>
    <groupId>net.sf.ehcache</groupId>
    <artifactId>ehcache</artifactId>
    <version>2.10.4</version>
</dependency>

2、创建配置文件,命名为ehcache.xml放在项目的classpath下:

<?xml version="1.0" encoding="UTF-8"?>
<ehcache>
    <!-- http://www.cnblogs.com/lzy1991/p/5335249.html http://www.cnblogs.com/little-fly/p/6251439.html
    缓存配置 diskStore:指定数据在磁盘中的存储位置。
    name:缓存名称。
     defaultCache:当借助CacheManager.add("demoCache")创建Cache时,EhCache便会采用<defalutCache/>
     指定的的管理策略,以下属性是必须的:
     maxElementsInMemory:缓存最大个数。
     eternal:对象是否永久有效,一但设置了,
     timeout将不起作用。
     timeToIdleSeconds:设置对象在失效前的允许闲置时间(单位:秒)。仅当eternal=false对象不是永久有效时使用,可选属性,默认值是0,也就是可闲置时间无穷大。
     timeToLiveSeconds:设置对象在失效前允许存活时间(单位:秒)。最大时间介于创建时间和失效时间之间。仅当eternal=false对象不是永久有效时使用,默认是0.,也就是对象存活时间无穷大。
     overflowToDisk:当内存中对象数量达到maxElementsInMemory时,Ehcache将会对象写到磁盘中。
     diskSpoolBufferSizeMB:这个参数设置DiskStore(磁盘缓存)的缓存区大小。默认是30MB。每个Cache都应该有自己的一个缓冲区。
     maxElementsOnDisk:硬盘最大缓存个数。
     diskPersistent:是否缓存虚拟机重启期数据 Whether the disk store persists between restarts of the Virtual Machine. The default value is false.
     diskExpiryThreadIntervalSeconds:磁盘失效线程运行时间间隔,默认是120秒。
     memoryStoreEvictionPolicy:当达到maxElementsInMemory限制时,Ehcache将会根据指定的策略去清理内存。默认策略是LRU(最近最少使用)。你可以设置为FIFO(先进先出)或是LFU(较少使用)。 c
     learOnFlush:内存数量最大时是否清除。 -->
    <diskStore path="e:\ehcache"/>
    <defaultCache maxElementsInMemory="10000" eternal="false" timeToIdleSeconds="120" timeToLiveSeconds="120"
                  overflowToDisk="true" maxElementsOnDisk="10000000" diskPersistent="false"
                  diskExpiryThreadIntervalSeconds="120" memoryStoreEvictionPolicy="LRU"/>

    <cache name="connectInfoCache" maxElementsInMemory="10000" eternal="false" timeToIdleSeconds="120" timeToLiveSeconds="120"
                  overflowToDisk="true" maxElementsOnDisk="10000000" diskPersistent="false"
                  diskExpiryThreadIntervalSeconds="120" memoryStoreEvictionPolicy="LRU"/>
</ehcache>

3、创建配置类,重点在@EnableCaching

@Configuration
@EnableCaching
public class EhcacheConfig {

    /*
     * 据shared与否的设置,Spring分别通过CacheManager.create()或new CacheManager()方式来创建一个ehcache基地.
     */
    @Bean("ehCacheManagerFactoryBean")
    public EhCacheManagerFactoryBean ehCacheManagerFactoryBean() {
        EhCacheManagerFactoryBean cacheManagerFactoryBean = new EhCacheManagerFactoryBean();
        cacheManagerFactoryBean.setConfigLocation(new ClassPathResource("ehcache.xml"));
        cacheManagerFactoryBean.setShared(true);
        return cacheManagerFactoryBean;
    }

    /*
      * ehcache 主要的管理器
      */
    @Bean
    public EhCacheCacheManager ehCacheCacheManager(EhCacheManagerFactoryBean ehCacheManagerFactoryBean) {
        return new EhCacheCacheManager(ehCacheManagerFactoryBean.getObject());
    }
}

4、需要缓存的类,注意需要实现Serializable

import java.io.Serializable;

public class ConnectInfo implements Serializable{

    private static final long serialVersionUID = 8727361463117425249L;

    private long projectId;//项目id
    private String projectName;//项目名称
    private String url;//连接域名地址
    private String ip;//
    private int port;//
    private String charset;//使用的字符集
    private String interfaceName;//接口名称
    private String params;//账号等参数
	getter/setter...
}

5、使用注释来进行缓存和查询缓存,为了统一出入口,创建一个cache类来管理:

@Repository
public class ConnectInfoCache {

    @Autowired
    private ProjectInterfaceMapRepository projectInterfaceMapRepository;

    @Cacheable(key = "#hallCode+#interfaceNam",value = "connectInfoCache")
    public ConnectInfo getConnectInfo(String hallCode, String interfaceName){
        System.out.println("没有走缓存");
        return projectInterfaceMapRepository.getConnectInfo(hallCode,interfaceName);
    }
}

ProjectInterfaceMapRepository 是数据库访问接口。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值