Echache整合Spring缓存实例讲解「建议收藏」

Echache整合Spring缓存实例讲解「建议收藏」Echache整合Spring缓存实例讲解

大家好,又见面了,我是你们的朋友全栈君。

摘要:本文主要介绍了EhCache,并通过整合Spring给出了一个使用实例。

一、EhCache 介绍

          EhCache 是一个纯Java的进程内缓存框架,具有快速、精干等特点,是Hibernate中默认的CacheProvider。Ehcache是一种广泛使用的开源Java分布式缓存。主要面向通用缓存,Java EE和轻量级容器。它具有内存和磁盘存储,缓存加载器,缓存扩展,缓存异常处理程序,一个gzip缓存servlet过滤器,支持REST和SOAP api等特点。

     它的一个缺点就是使用磁盘Cache的时候非常占用磁盘空间,这源于DiskCache的算法简单,该算法简单也导致Cache的效率非常高。它只是对元素直接追加存储。因此搜索元素的时候非常的快。如果使用DiskCache的,在很频繁的应用中,很快磁盘会满。
另外一个问题是当突然kill掉java的时候,不能保证数据的安全,可能是产生冲突,Ehcache的解决方法是如果文件冲突了,则重建cache。这对于Cache数据需要保存的时候可能不利。当然,Cache只是简单的加速,而不能保证数据的安全。如果想保证数据的存储安全,可以使用Bekeley DB Java Edition版本。这是个嵌入式数据库。可以确保存储安全和空间的利用率。当然,还有很多的Cache。多数情况下,Ehcache能满足常见需求。

二、使用实例

本文要使用

1、引入jar包

[html] 
view plain
copy

  1.     <dependency>  
  2.     <groupId>net.sf.ehcache</groupId>  
  3.     <artifactId>ehcache</artifactId>  
  4.     <version>2.8.2</version>  
  5. </dependency>  


2、在classpath下增加ehcache配置文件 ehcache.xml与配置文件

Echache整合Spring缓存实例讲解「建议收藏」

设置控制ehcache的bean,这部分的内容也可以直接写在spring的配置文件applicationContext.xml中去,这里为了方便管理,我给单独写出来了

beans-cache.xml

[html] 
view plain
copy

  1. <?xml version=“1.0” encoding=“UTF-8”?>  
  2. <beans xmlns=“http://www.springframework.org/schema/beans”  
  3.     xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instance” xmlns:cache=“http://www.springframework.org/schema/cache”  
  4.     xmlns:p=“http://www.springframework.org/schema/p”  
  5.     xsi:schemaLocation=”   
  6.         http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd            
  7.         http://www.springframework.org/schema/cache http://www.springframework.org/schema/cache/spring-cache-3.1.xsd”>  
  8.   
  9.     <cache:annotation-driven cache-manager=“cacheManager” />  
  10.   
  11.     <bean id=“cacheManager” class=“org.springframework.cache.ehcache.EhCacheCacheManager”>  
  12.         <property name=“cacheManager” ref=“ehcache”></property>  
  13.     </bean>  
  14.   
  15.     <bean id=“ehcache”  
  16.         class=“org.springframework.cache.ehcache.EhCacheManagerFactoryBean”>  
  17.         <property name=“configLocation” value=“classpath:beans/ehcache.xml”></property>  
  18.     </bean>  
  19.   
  20. </beans>   

ehcache.xml设置缓存大小和时间,缓存空间名等。其中缓存空间可设置多个

[html] 
view plain
copy

  1. <?xml version=“1.0” encoding=“UTF-8”?>  
  2. <ehcache updateCheck=“false”>  
  3.   
  4.     <diskStore path=“java.io.tmpdir” />  
  5.   
  6.     <!– DefaultCache setting. –>  
  7.     <defaultCache eternal=“false”   
  8.                   overflowToDisk=“false”   
  9.                   diskPersistent=“false”   
  10.                   timeToLiveSeconds=“36000”   
  11.                   timeToIdleSeconds=“36000”   
  12.                   maxElementsInMemory=“10000”   
  13.                   memoryStoreEvictionPolicy=“LRU”/>  
  14.   
  15.     <!– Special objects setting. –>  
  16.     <!– Refresh sysParamCache every hour. –>  
  17.     <cache name=“sysParamCache”   
  18.            overflowToDisk=“false”   
  19.            eternal=“false”   
  20.            diskPersistent=“false”   
  21.            timeToLiveSeconds=“36000”   
  22.            timeToIdleSeconds=“36000”   
  23.            maxElementsInMemory=“10000”   
  24.            memoryStoreEvictionPolicy=“LRU”/>  
  25.       
  26. </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(先进先出)。

3.spring配置文件 applicationContext.xml 添加ehcache的配置

[plain] 
view plain
copy

  1. <import resource=”classpath:beans/beans-cache.xml” />   

4.在service层增加注解配置

[java] 
view plain
copy

  1. @Override  
  2. @Cacheable(value=“sysParamCache”,key=“#systemId+#merchantId+#businessType”)// 使用了一个缓存名叫 accountCache     
  3. public SettUnit getSettUnitBySettUnitId(String systemId, String merchantId, String businessType) {  

key=#systemId+#merchantId+#businessType” 对象缓存的key值,需要保证唯一, 用的是Spring的 SpEL表达式, 取值为 isbn对象的id属性值

value=”sysParamCache”:指的是ehcache.xml里的缓存名字

5、单元测试

[java] 
view plain
copy

  1. @Test   
  2. public void getSettUnitBySettUnitIdTest() {  
  3.     String systemId = “CES”;  
  4.     String merchantId = “133”;  
  5.     SettUnit configSettUnit = settUnitService.getSettUnitBySettUnitId(systemId, merchantId, “ESP”);  
  6.     SettUnit configSettUnit1 = settUnitService.getSettUnitBySettUnitId(systemId, merchantId, “ESP”);  
  7.     boolean flag= (configSettUnit == configSettUnit1);  
  8.     System.out.println(configSettUnit);  
  9.     logger.info(“查找结果” + configSettUnit.getBusinessType());  
  10.     
  11.   //  localSecondFIFOCache.put(“configSettUnit”, configSettUnit.getBusinessType());  
  12.  //  String string = localSecondFIFOCache.get(“configSettUnit”);  
  13.       logger.info(“查找结果” + string);  
  14. }  

这是有缓存的结果,第二次直接从缓存中去取,比较两个的地址,相等即表明两上是同一个对象,第二次取的是第一次的结果

Echache整合Spring缓存实例讲解「建议收藏」

这是第一次取结果打印的SQL语句

Echache整合Spring缓存实例讲解「建议收藏」

转载于:https://my.oschina.net/zhanghaiyang/blog/593061

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106768.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 手写IoU(u音标手写怎么写)

    IoU(IntersectionoverUnion)矩形框的IoU计算:矩阵T的左下角坐标,右上角坐标;矩阵G的左下角坐标,右上角坐标;在确定坐标的情况下,与是可知的常量,所以,我们只需要求解即可。这里我们先来看一下水平方向上的情况:从上述的三种情况中我们可以看出:当有重叠或者是内含的情况时,我们可以通过计算得到重叠部分的长度….

    2022年4月15日
    68
  • 什么是互联网,以太网,广域网,局域网的代码_局域网和广域网和城域网的区别

    什么是互联网,以太网,广域网,局域网的代码_局域网和广域网和城域网的区别计算器网络

    2022年10月9日
    0
  • 文件锁的使用浅析_文件加密软件

    文件锁的使用浅析_文件加密软件概述在多数unix系统中,当多个进程/线程同时编辑一个文件时,该文件的最后状态取决于最后一个写该文件的进程。对于有些应用程序,如数据库,各个进程需要保证它正在单独地写一个文件。这时就要用到文件锁。文件锁(也叫记录锁)的作用是,当一个进程读写文件的某部分时,其他进程就无法修改同一文件区域。能够实现文件锁的函数主要有2个:flock和fcntl。早期的伯克利版本只支持flock,该…

    2022年4月19日
    61
  • Oracle19c安装教程及PLSQL配置常见错误解决办法

    Oracle19c安装教程及PLSQL配置常见错误解决办法本人电脑上也装了不少比较难以安装的程序,而且也亲身破解了一些软件,自己以前也安装过MySQL和DB2,原以为Oracle也差不多,直到我亲身经历了,我才知道什么是痛苦。帅帅本人在经历了长时间的折磨之后终于把Oracle安装完毕,可谓被折磨得一塌糊涂,暗无天日。或许这也是程序员的快乐之一吧(ง•_•)ง目录&下面是Oracle的一些安装步骤及安装过程中常见错误的修正…

    2022年5月20日
    476
  • sudo :apt-get:command not found

    sudo :apt-get:command not found

    2021年10月8日
    42
  • 使用BoundsChecker「建议收藏」

     BoundsChecker是一个Run-Time错误检测工具,它主要定位程序在运行时期发生的各种错误。              BoundsChecker能检测的错误包括:3sNews.Net——3S社区&资讯平台tbU^N@i7pwMVBe    1)指针操作和内存、资源泄露错误,比如:内存泄露;资源泄露;对指针变量的错误操作。   

    2022年4月7日
    52

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号