美文网首页
2019-05-15 spring cache Ecache

2019-05-15 spring cache Ecache

作者: sickle4j | 来源:发表于2019-05-15 17:59 被阅读0次

    首先在pom.xml中添加依赖:

        <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-cache</artifactId>
            </dependency>
    

    关于ecache的配置文件:

    <?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"/>
    
        <defaultCache eternal="false"   //对象是否永久有效,一但设置了,timeout将不起作用。 
                      maxElementsInMemory="1000"  //缓存最大个数。
                      overflowToDisk="false"  //当内存中对象数量达到maxElementsInMemory时,Ehcache将会对象写到磁盘中。 
                      diskPersistent="false"  //是否缓存虚拟机重启期数据,磁盘必须在重启的时间内存在,默认是false  
                      timeToIdleSeconds="0"  //设置对象在失效前的允许闲置时间(单位:秒)。仅当eternal=false对象不是永久有效时使用,可选属性,默认值是0,也就是可闲置时间无穷大。 
                      timeToLiveSeconds="600"  /设置对象在失效前允许存活时间(单位:秒)。最大时间介于创建时间和失效时间之间。仅当eternal=false对象不是永久有效时使用,默认是0.,也就是对象存活时间无穷大。 
                      memoryStoreEvictionPolicy="LRU"/> //当达到maxElementsInMemory限制时,Ehcache将会根据指定的策略去清理内存。默认策略是LRU(最近最少使用)。你可以设置为FIFO(先进先出)或是LFU(较少使用)。
    
        <cache name="orderCache"  //
               maxElementsInMemory="1000"
               eternal="false"
               timeToIdleSeconds="600"
               timeToLiveSeconds="600"
               overflowToDisk="false"
               memoryStoreEvictionPolicy="LRU"/>
    </ehcache>
    
    diskSpoolBufferSizeMB:这个参数设置DiskStore(磁盘缓存)的缓存区大小。默认是30MB。每个Cache都应该有自己的一个缓冲区。 
    clearOnFlush:内存数量最大时是否清除。 
    diskExpiryThreadIntervalSeconds:磁盘失效线程运行时间间隔,默认是120秒。
    

    在springboot中使用注解 使用ecache:

    @Cacheable(key = "'order_'+#orderNo", unless = "#result == null", value = "orderCache")

    • value (也可使用 cacheNames) : 可看做命名空间,表示存到哪个缓存里了。
    • key : 表示命名空间下缓存唯一key,使用Spring Expression Language(简称SpEL,详见参考文献[5])生成。
    • condition : 表示在哪种情况下才缓存结果(对应的还有unless,哪种情况不缓存),同样使用SpEL

    @CacheEvict(value = "models", allEntries = true)

    • value (也可使用 cacheNames) : 同Cacheable注解,可看做命名空间。表示删除哪个命名空间中的缓存
    • allEntries: 标记是否删除命名空间下所有缓存,默认为false
    • key: 同Cacheable注解,代表需要删除的命名空间下唯一的缓存key。

    @CachePut(key = "'order_'+#order.orderNo", value = "orderCache")

    • value: 同上
    • key: 同上
    • condition(unless): 同上

    相关文章

      网友评论

          本文标题:2019-05-15 spring cache Ecache

          本文链接:https://www.haomeiwen.com/subject/vidmaqtx.html