gpt4 book ai didi

java - 在 Wildfly 8.2 上重新部署后从 Infinispan 缓存读取时发生 ClassCastException

转载 作者:搜寻专家 更新时间:2023-11-01 03:21:05 25 4
gpt4 key购买 nike

我在 Wildfly 8.2 上有一个简单的 Infinispan 本地缓存(也尝试过分布式缓存)。一切正常,直到我重新部署我的 .WAR。重新部署我的 .WAR 后,出现以下错误:

Caused by: java.lang.ClassCastException: my.package.MyClass cannot be cast to my.package.MyClass

完整堆栈跟踪:https://gist.github.com/bagges/07af1842a874f7c99ef3

我像这样在 CDI Bean 中查找缓存:

@Path("/mypath")
@Stateless
public class MyServiceClass {

@Resource(lookup = "java:jboss/infinispan/myContainer")
private CacheContainer container;

private Cache<Integer, MyCacheObject> myCache;

@PostConstruct
public void start() {
myCache = container.getCache("myCache");
}

@GET
public String get() {
if(!myCache.containsKey(1)) {
myCache.put(1, new MyCacheObject(1, "Hello Cache"));
}
return myCache.get(1).getName();
}
}

Wildfly 配置:

<cache-container name="myContainer" jndi-name="java:jboss/infinispan/myContainer" start="EAGER">
<local-cache name="myCache"/>
</cache-container>

我知道错误发生是因为关闭了不同的类加载器。 Infinispan 尝试转换存储在先前无法工作的类加载器中的实体。但是如何避免呢?

最佳答案

不要使用 start="EAGER"。那将解决您的问题。我们已将其从 WildFly 9 中删除,因为它的滥用一直是许多用户头痛的根源。

此外,我建议直接注入(inject)您的缓存(而不仅仅是缓存容器)。这样,缓存生命周期将绑定(bind)到部署的生命周期。例如

@Resource(lookup = "java:jboss/infinispan/cache/myContainer/myCache")
private Cache<Integer, MyCacheObject> myCache;

最后,请随意使用资源引用以避免在您的应用程序中引用特定于供应商的 jndi 命名空间。

关于java - 在 Wildfly 8.2 上重新部署后从 Infinispan 缓存读取时发生 ClassCastException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30483372/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com