我们在项目中使用 ehcache 进行缓存。
import com.googlecode.ehcache.annotations.Cacheable;
// Other imports
@Component
public class Authenticator{
@Cacheable(cacheName = "rest_client_authorized")
public boolean isUserAuthorized(final String user, final String sessionId) {
// Method code
}
}
进入方法时没有缓存拦截器。到目前为止我们检查过的事情:
- 我们不是从类内部调用这个方法,而是从外部调用。所以问题不在于内部调用导致绕过代理。
- 我们为此类添加了一个接口,并且更改了调用此类的注入以使用接口表示形式而不是具体类。
我们在应用程序上下文中定义了缓存管理器,如下所示:
<ehcache:annotation-driven cache-manager="ehCacheManager" />
<bean id="ehCacheManager" class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean">
<!-- use a share singleton CacheManager -->
<property name="shared" value="true" />
</bean>
缓存的定义如下:
<cache name="rest_client_authorized"
eternal="false"
maxElementsInMemory="50"
overflowToDisk="false" diskPersistent="false"
timeToIdleSeconds="0" timeToLiveSeconds="600"
memoryStoreEvictionPolicy="LRU" />
当我们使用 Jconsole 测试缓存管理器时,我们可以看到缓存 *rest_auth_disabled* 存在且为空。
任何关于为什么这不起作用的想法将不胜感激。谢谢!
更新(来自下面评论的汇总):
===========================================**
这是一个遗留代码,可以很好地与我提供的类和定义配合使用。我在这里谈论的方法是新的,但班上的其他人过去确实有效。因此,我们正在努力了解发生了什么变化。我们也已经尝试将注释替换为 spring Cacheable,但仍然没有任何结果:/
也许这取决于调用这个新方法的代码,它来自与我们用于其他方法的不同的 spring bean。但我还是找不到问题所在。
还尝试按照下面的答案返回布尔值而不是布尔值,但它不起作用。
我们有一个新的线索,它可能与我们注入 bean 的方式有关(使用@Autowire)。如果确实如此,将会更新。