问题描述
在我的应用程序中,ehcache的配置如下。
In my application the ehcache is configured as below.
AppDataRegion.java
AppDataRegion.java
//import statements.
public class AppDataRegion{
//Variable for region identifier.
private String appRegionId;
// constructor sets the appRegionId;
//obtained from the system current time.
public AppDataRegion(){
appRegionId = String.valueOf(System.currentTimeMillis());
}
//Variable for cachemanager
// injected by spring DI from context xml
Private CacheManager appCacheMngr;
//necessary getter / setter methods for variable cachemanager
//necessary getter / setter methods for variable appRegionId
//method to create a region in cache using the appRegionId value
private createRegion(){
if (!appCacheMngr.cacheExists(appRegionId)){
try {
appCacheMngr.addCache(appRegionId);
catch (exc){
//exception handled
}
}
}
public Cache getRegion(){
if(appCacheMngr == null || !appCacheMngr.cacheExists(appRegionId)){
createRegion();
}
return appCacheMangr.getCache(appRegionId);
}
private createCustRegion(){
try{
Cache custCache = appCacheMngr.getCache("custdiskCache");
If(null == custCache.addCache(custCache);
}catch (exp){
//handled the exceptions
}
retrun appCacheMngr.getCache("custdiskCache");
}
}
Spring配置
<bean id="appDataStoreService" class="com.app.cache.AppDataStoreService" >
<property name="appDataStoreRegion" ref="appDataStoreRegion"/>
</bean>
<bean id="appDataStoreRegion" class="com.app.cache.AppDataStoreRegion">
<property name="appcacheManager" ref="cacheManager"/>
</bean>
<bean id="cacheManager" class="net.sf.ehcache.CacheManager" factory-method="create">
<constructor-arg index="0" type="java.net.URL" value="classpath:ehcache-app.xml" />
</bean>
///应用数据存储区有一个服务层地区。
//There is a service layer for the app data store region.
public class AppDataStoreService{
//datastoreregion variable declaration
private AppDataStoreRegion appDataStoreRegion;
public void storeCustObjInCache(String id, Object obj){
Cache region = appDataStoreRegion.getCustRegion();
If(region != null && id !=null && region.isElementInMemory(id)){
region.remove(id);
}
Element ele = new Element(id, obj);
If(region != null) region.put(ele);
}
}
在DTO对象中填充数据后,在应用程序内我调用appDataStoreService类的storeCustObjInCache()方法将内容写入磁盘。
Within the application after populating the data in the DTO object I call the storeCustObjInCache() method of appDataStoreService class to write the content to disk.
将ehcache配置为单例而不是实例。
The ehcache is configured as singleton rather than instance.
Web应用程序使用Struts(2.3.20)框架进行Web流,使用Spring框架(4.1.2)进行DI对象管理。
The web application uses struts (2.3.20) framework for web flow and Spring framework (4.1.2) for DI object management.
也JSP for UI我们迭代了使用bean对象,该对象具有用于显示内容的列表。
Also JSP for UI we iterate the use bean object which has list to display contents.
我们从1.2.2迁移到ehcache 2.9.0,只是在春季改变了jar和配置xml上下文。迁移之后,我们开始经常收到以下异常。
We migrated to ehcache 2.9.0 from 1.2.2 just changing the jar and configuration in spring xml context. After the migration we started getting the below exception frequently.
我理解为什么会这样,当ehcache试图向磁盘写入数据时,另一个线程正在修改序列化列表。我找不到哪个线程以及它的可能性。
My understanding why this happens is, when the ehcache is trying to write to the disk another thread is modifying the serialized list.I couldn't find out which thread and the possibility for it.
是否有一个示例,说明如何在春季之内以编程方式使用ehcache而无需注释。
Is there an example on how to use the ehcache using programmatically like this without annotation within spring.
关于如何识别导致此问题的线程
And any insight on how to identify the thread that causing this issue
推荐答案
您有两个选择:
- 查找所有在缓存对象后将其突变的代码路径
- 确保缓存的内容是不变的
如果您能以这种方式重构应用程序,我会选择选项2。
I would favour option 2 if you can refactor your application that way.
此问题绝对不是由连接不同的参与者对象的方式,顺便说一下,在提供的示例中它不使用注释。
This problem is absolutely not caused by the way you wire the different participant objects, which by the way does not use annotations in the example provided.
这篇关于使用+ Spring + Struts应用程序的Ehcache并发修改异常的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!