- 浏览: 1543419 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (225)
- JAVA (27)
- Spring (49)
- Linux (51)
- JavaScript (8)
- Scrum (23)
- IDE (2)
- JSON (2)
- Solr (0)
- Webharvest (0)
- Hibernate (8)
- 杂谈 (3)
- Windows 7 (4)
- 持续集成 (23)
- tomcat (3)
- Android (1)
- SpringSecurity (11)
- Maven (9)
- jotm (3)
- C3P0 (1)
- Active Directory (2)
- cas (1)
- JQuery (2)
- ajax (1)
- plsql (2)
- nginx (4)
- apache (1)
- thrift (7)
- python (3)
- oracle (4)
- php (2)
- redis (1)
- fedora (1)
- windows7 (0)
- SVN (1)
- NFS (1)
- SAMBA (1)
- Atomikos (1)
- apache-poi (1)
- mysql (2)
- vncserver (1)
- mac (2)
- firefox (1)
- JIRA (1)
- p6spy (1)
- git (1)
- github (1)
- gitlab (1)
- gogs (1)
- Druid (1)
- MyBatis (1)
- docker (8)
- zabbix (1)
最新评论
-
lialatd:
您好,我用您的方法通过java api往jira系统中添加is ...
JIRA REST API ---- JAVA -
sprcen945:
可以了,是因为没加intercept-url 的拦截, 尼玛, ...
SpringSecurity3.X--Cas client 配置 -
sprcen945:
请问为什么我配了security.xml后切入点不起作用(之前 ...
SpringSecurity3.X--Cas client 配置 -
linxingyul:
根据楼主的代码 继承了WebMvcConfigurationS ...
SpringMVC4零配置--Web上下文配置【MvcConfig】 -
java_老头:
MvcConfig.java的FilterType.ANNOT ...
SpringMVC4零配置--Web上下文配置【MvcConfig】
关于Spring3.1 Cache注解的介绍请参看http://hanqunfeng.iteye.com/blog/1158824
这里只说一下遇到的问题,web应用,session超时为30分钟,使用Cache注解+EHCache,如下:
<cache name="andCache" maxElementsInMemory="10000" maxElementsOnDisk="1000" eternal="false" overflowToDisk="true" diskSpoolBufferSizeMB="20" timeToIdleSeconds="300" timeToLiveSeconds="600" memoryStoreEvictionPolicy="LFU" /> 说明:缓存名andCache,内存中最多可缓存10000个Element,其中的element会在闲置5分钟或是存活10分钟之后失效, 超过10000element时,element将会输出到磁盘中。
结果,在登录系统后,如果超过5分钟不访问系统,则会出现异常,
按照这样配置,我原以为,如果5分钟之内不访问应用,则缓存会失效,那么spring就会重新执行原先被缓存的方法,但实际上,方法并没有被重新执行,而是返回了null,貌似spring依旧是从缓存中查找,并且找到了key,只不过value已经是null了。
这样就会导致系统出现空指针异常,况且session也尚未超时,
但就算是将闲置时间设置为30分钟以上,用户在下次登录时一样会出现异常,但是第二次登录就又会正常,然后周而复始,貌似,只有当第一次取到null后,spring才会重新执行方法。
感觉上,好像ehcache清除缓存后,spring并不知道,因为key依旧可以在spring的cache中找到,但是通过key取值时,spring会从ehcache中查找,由于ehcache已经清除了缓存,所以返回值一定是null,而spring也把这个null当成了被缓存的value返回给系统。
使用spring自带的缓存机制没有遇到该问题。
评论
5 楼
xiaoyaozjl
2013-04-08
LZ使用的是spring 3.1.0.M1版本,也就是里程碑版本非正式版,是存在这个问题的。在spring 3.1.0.M2里面已经修正了。
3.1.0.M1版本的org.springframework.cache.ehcache.EhCacheCache.java:
3.1.0.M2版本的org.springframework.cache.ehcache.EhCacheCache.java:
3.1.0.M1版本的org.springframework.cache.ehcache.EhCacheCache.java:
public Object get(Object key) { Element element = cache.get(key); return (element != null ? element.getObjectValue() : null); }
3.1.0.M2版本的org.springframework.cache.ehcache.EhCacheCache.java:
public ValueWrapper get(Object key) { Element element = cache.get(key); return (element != null ? new DefaultValueWrapper<Object>(element.getObjectValue()) : null); }
4 楼
yaofaye
2013-02-26
对的,返回的null是,key对应的value值为null,并不是Cache.ValueWrapper为null,客户端判断一下value值,如果为null,返回一个null的Cache.ValueWrapper即可。
从源码上看不应该是这样吧?
代理方法会拦截并判断Cache.ValueWrapper是否为空,如果为空直接invoke原方法,返回原方法中查询出来的对象
songbin0201 写道
引用
但实际上,方法并没有被重新执行,而是返回了null,貌似spring依旧是从缓存中查找,并且找到了key,只不过value已经是null了。
从源码上看不应该是这样吧?
代理方法会拦截并判断Cache.ValueWrapper是否为空,如果为空直接invoke原方法,返回原方法中查询出来的对象
// follow up with cacheable //inspectCacheables根据cachename验证Cache.ValueWrapper是否为空 CacheStatus status = inspectCacheables(ops.get(CACHEABLE)); Map<CacheOperationContext, Object> updates = inspectCacheUpdates(ops.get(UPDATE)); if (status != null) { if (status.updateRequired) { updates.putAll(status.cUpdates); } // return cached object else { return status.retVal; } } retVal = invoker.invoke();//retVal如果为空,直接调用原方法,返回非缓存数据
inspectCacheables方法中关于验证Cache.ValueWrapper的代码,为空设置localCacheHit 为false,localCacheHit为false,设置需要重新更新cache boolean localCacheHit = false; // check whether the cache needs to be inspected or not (the method will be invoked anyway) if (!updateRequire) { for (Cache cache : context.getCaches()) { Cache.ValueWrapper wrapper = cache.get(key); if (wrapper != null) { retVal = wrapper.get(); localCacheHit = true; break; } } } if (!localCacheHit) { updateRequire = true; }
3 楼
songbin0201
2012-12-17
引用
但实际上,方法并没有被重新执行,而是返回了null,貌似spring依旧是从缓存中查找,并且找到了key,只不过value已经是null了。
从源码上看不应该是这样吧?
代理方法会拦截并判断Cache.ValueWrapper是否为空,如果为空直接invoke原方法,返回原方法中查询出来的对象
// follow up with cacheable //inspectCacheables根据cachename验证Cache.ValueWrapper是否为空 CacheStatus status = inspectCacheables(ops.get(CACHEABLE)); Map<CacheOperationContext, Object> updates = inspectCacheUpdates(ops.get(UPDATE)); if (status != null) { if (status.updateRequired) { updates.putAll(status.cUpdates); } // return cached object else { return status.retVal; } } retVal = invoker.invoke();//retVal如果为空,直接调用原方法,返回非缓存数据
inspectCacheables方法中关于验证Cache.ValueWrapper的代码,为空设置localCacheHit 为false,localCacheHit为false,设置需要重新更新cache boolean localCacheHit = false; // check whether the cache needs to be inspected or not (the method will be invoked anyway) if (!updateRequire) { for (Cache cache : context.getCaches()) { Cache.ValueWrapper wrapper = cache.get(key); if (wrapper != null) { retVal = wrapper.get(); localCacheHit = true; break; } } } if (!localCacheHit) { updateRequire = true; }
2 楼
jahu
2012-12-15
登录用户,不用缓存吧,
1 楼
snowolf
2012-09-24
多个应用,分布式部署,缓存数据如何保持一致性?
发表评论
-
Druid学习笔记
2016-10-07 11:55 2523官方网站:https://github.com/aliba ... -
JIRA REST API ---- JAVA
2015-09-24 15:51 13429最近在搞自动化监控 ... -
Spring Cache注解+Redis
2015-01-15 13:36 54528Spring3.1 Cache注解 依赖jar包: ... -
Spring Cache注解+Memcached
2015-01-12 16:11 20503Spring3.1 Cache注解 依赖jar包: ... -
Spring4+Hibernate4+Atomikos3.3多数据源事务管理
2014-09-25 10:46 8430Spring3+后不再对JTOM提供支持,所以可以改用At ... -
SpringMVC4零配置--Web上下文配置【MvcConfig】
2014-09-10 18:22 73505与SpringSecurity的配置类似,spring同样 ... -
SpringMVC4零配置--SpringSecurity相关配置【SpringSecurityConfig】
2014-09-10 18:22 72048SpringSecurity的配置相对来说有些复杂,如果 ... -
SpringMVC4零配置--应用上下文配置【AppConfig】
2014-09-10 18:21 26611从spring3.0开始,Spring将JavaConfi ... -
SpringMVC4零配置--web.xml
2014-09-10 18:21 98772servlet3.0+规范后,允许servlet,filt ... -
SpringMVC4零配置
2014-09-05 19:11 90053基于Servlet3.0规范和SpringMVC4注解式配 ... -
SpringSecurity3.X--LDAP:AD配置
2014-07-08 17:08 5588前面介绍过基于本地数据库验证的方式,参考http://ha ... -
Thrift--JSClient
2013-09-26 14:45 6023thrift提供了基于jquery--ajax的客户端调用 ... -
Thrift--Spring集成ThriftServlet
2013-09-25 11:42 11165Thrift除了可以通过TCP协议访问,还可以通过HTTP ... -
Thrift转SpringHttpInvoker
2013-09-24 13:26 1809关于在spring中集成Thrift请参看:http://h ... -
Thrift--JavaServer&PythonClient遇到的问题
2013-09-23 10:16 1483thrift在java中的应用参考:http://hanqu ... -
Spring集成Thrift--Server AND Client
2013-09-04 20:13 13795Thrift网上有N多教程, ... -
Windows Server 2008 Active Directory 安装及使用笔记
2013-03-22 18:49 26991.安装AD http://www.docin.com/ ... -
C3P0配置实战
2012-09-04 18:34 51942C3P0: 一个开源的JDBC连接池,它实现了数据源和JN ... -
spring+jotm 多数据源事务管理(三)JNDI+Tomcat
2012-06-07 16:27 5320spring+jotm 多数据源事务管理系列 spr ... -
spring+jotm 多数据源事务管理(二)hibernate
2012-06-07 11:20 2922spring+jotm 多数据源事务管理系列 spr ...
相关推荐
Spring 3.1的缓存抽象提供了一种统一的方式来管理和使用缓存。它不仅支持简单的缓存存储,如 EhCache 和 Hazelcast,还允许与复杂的分布式缓存系统如 Redis 和 Guava 集成。通过注解驱动的编程模型,开发者可以在...
Spring框架自3.1版本开始引入了统一的缓存抽象,支持多种缓存实现,其中包括EhCache。Spring的缓存抽象层使得切换缓存提供商变得简单,而无需改动大量代码。 **3. 配置Spring与EhCache** 在Spring中使用EhCache,...
Spring框架自3.1版本起引入了抽象的缓存管理机制,允许开发者选择不同的缓存实现,如Ehcache、Guava Cache等。通过声明式或编程式的缓存注解,可以轻松地在方法级别启用缓存功能。 集成Ehcache,首先需要在项目中...
例如,使用`<cache:advice>`和`<cache:annotation-driven>`元素可以关联缓存注解与具体的缓存策略。 6. **缓存异常处理**:Spring提供了一套完整的异常处理机制,当缓存操作失败时,可以配置异常处理器来决定如何...
### Spring与ehcache结合使用详解 #### 一、前言 在现代软件开发中,缓存技术被广泛应用于提高应用程序的性能。其中,Spring框架因其灵活性和强大的功能,在Java领域得到了广泛应用;而ehcache作为一款高性能、...
新增了Cache抽象,提供了一种统一的缓存管理接口,支持Ehcache、Guava等主流缓存库,方便实现高效的缓存策略。 7. **表达式语言(SpEL)** Spring Expression Language在3.1版本中增强了其功能,支持更多的操作符...
本篇文章将深入探讨如何使用注解配置Spring与EHCache或OSCache这两个流行的Java缓存解决方案。以下是对该主题的详细阐述: 1. **Spring缓存抽象** Spring 3.1引入了一种统一的缓存抽象,它允许开发者在不关心具体...
1、SpringCache是Spring提供的一个缓存框架,在Spring3.1版本开始支持将缓存添加到现有的spring应用程序中,在4.1开始,缓存已支持JSR-107注释和更多自定义的选项 2、Spring Cache利用了AOP,实现了基于注解的缓存...
Spring Cache 是 Spring 3.1 版本引入的一项重要特性,它不是一种具体的缓存实现(如 EHCache 或 OSCache),而是一种缓存使用的抽象层。通过在现有的业务代码上添加特定的注解,可以轻松地为方法调用添加缓存支持。...
从 Spring 3.1 版本开始,Spring 框架正式引入了对 Cache 的支持,这种支持的方式和原理与 Spring 对事务管理的支持非常类似。通过这种方式,开发人员可以在不增加大量额外代码的情况下轻松地集成缓存技术,从而提高...
### Ehcache分布式缓存及其在Spring中的应用 #### 一、Ehcache概述与原理 Ehcache是一款高效且轻量级的纯Java缓存框架,由于其出色的性能和易于集成的特点,在Java开发中有着广泛的应用。作为Hibernate的默认缓存...
Spring Cache 是 Spring 框架的一个模块,自 3.1 版本起引入,提供了基于注解的缓存抽象,使得开发者能够方便地在应用中集成和管理缓存。 一、Spring Cache 介绍 Spring Cache 提供了一种统一的方式来管理不同类型...
Spring整合EhCache是一个常见的缓存管理方案,尤其在企业级Java应用中广泛使用。Spring框架提供了对多种缓存技术的支持,包括EhCache,这使得我们能够在Spring应用中轻松地实现数据缓存,提高系统性能。下面我们将...
### Spring实现Cache简单解决方案 #### 一、背景与概述 在现代软件开发中,缓存是一种常见的优化手段,用于提高应用程序的性能。Spring框架作为Java领域最流行的开发框架之一,为开发者提供了丰富的缓存管理机制。...
Spring Cache 是 Spring 框架从 3.1 版本开始引入的一种注解驱动的缓存抽象,它提供了一种简单而灵活的方式来在应用程序中实现缓存功能,无需依赖特定的缓存实现,如 EhCache 或 OSCache。Spring Cache 的核心特性...
Spring Cache 是 Spring 框架从 3.1 版本开始引入的一个强大特性,它提供了一种透明化的缓存机制,允许开发者在不修改原有业务代码的基础上,轻松地为应用程序添加缓存功能。这个抽象层使得我们可以使用不同的缓存...
Spring Cache 是Spring框架提供的一种缓存抽象,从Spring 3.1版本开始引入,目的是为了简化应用程序中的缓存管理,实现缓存透明化。通过在方法上添加特定注解,如@Cacheable、@CacheEvict等,可以轻松地启用缓存功能...
尽管 Ehcache 已经发布到了 3.1 版本,但本文将以 2.10.2 版本为基础进行讲解,因为 Spring 4.x 版本尚不直接支持 Ehcache 3.x。尽管可以通过 JCache API 进行间接整合,但这可能会增加复杂性。 ### 安装 Ehcache ...
要使用Spring Cache,我们需要在Spring配置中声明缓存管理器(如Ehcache、Redis等),并启用缓存注解处理。配置可以是基于XML的,也可以是基于Java配置。例如,使用Ehcache时,我们需要引入Ehcache库,并在配置中...
12. **缓存抽象**:Spring 3.1引入了缓存抽象,支持Ehcache、Hazelcast等缓存系统,相关接口位于`org.springframework.cache`包下。 通过阅读和分析Spring 3.1.4的源码,开发者可以深入了解Spring框架的设计理念和...