java - ConcurrentModification EHCache 多线程 Java
问题描述
我们有多个线程试图从 EHCache 获取,这有时会导致并发修改异常。我尝试 Retryable 来解决这个问题,但它似乎没有做任何事情。有什么建议么?
@Override
@Retryable(include= ConcurrentModificationException.class, backoff = @Backoff(delay = 5000, maxDelay = 3000), maxAttempts = 5)
public Object getFromCache(String cacheDomain, String cacheKey) {
Object value = null;
Cache cacheObject = getCacheObject();
if (cacheObject != null) {
StringBuilder fullCacheKey = new StringBuilder();
fullCacheKey.append(cacheDomain);
fullCacheKey.append("|");
fullCacheKey.append(cacheKey);
synchronized (cacheObject) {
Element cacheElement = cacheObject.get(fullCacheKey.toString());
if (cacheElement != null) {
value = cacheElement.getObjectValue();
}
}
log.debug("Value from Cache with key [" + fullCacheKey.toString() + "] is " + value);
}
return value;
}
解决方案
我现在正在方法中进行深层复制以防止此错误。这可能会产生任何无法预料的后果吗?该方法只会从缓存中获取,所以我相信不会有任何影响
元素 cacheElement = (Element) SerializationUtils.clone(cacheObject.get(fullCacheKey.toString()));
推荐阅读
- websocket - 如何在没有 Python 的情况下生成本地 SDP
- c# - Linq 从嵌套元素连接和投影
- dart - 颤振:刮刮卡
- beagleboneblack - unexport 不适用于 BBB GPIO
- c# - 应用程序对象在 wpf 的 ViewModel 中为空,试图访问应用程序变量
- vuepress - 在 Vuepress 中是否有一种简洁的方式来包含组件?
- python - aws-lambda 函数中的异常处理
- c# - 在 WPF 模型中发现用户偏好和更改的最佳方式
- python - Django rest_framework:如何将附加属性传递给异常/错误响应?
- ruby - 如何在 victor 中生成混合大小写的 SVG 元素,例如 flowRegion