首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Infinispan使用共享文件存储时获取"java.io.IOException:不支持的协议版本22“

在Infinispan使用共享文件存储时获取"java.io.IOException:不支持的协议版本22“
EN

Stack Overflow用户
提问于 2016-11-02 06:14:30
回答 1查看 2.4K关注 0票数 1

我在使用基于文件存储的缓存存储时获得了以下异常,该缓存存储在多个节点之间共享。

代码语言:javascript
复制
Caused by: org.infinispan.commons.CacheException: Unable to start cache loaders
    at org.infinispan.persistence.manager.PersistenceManagerImpl.start(PersistenceManagerImpl.java:174)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.infinispan.commons.util.ReflectionUtil.invokeAccessibly(ReflectionUtil.java:168)
    ... 73 more
Caused by: org.infinispan.persistence.spi.PersistenceException: java.io.IOException: Unsupported protocol version 22
    at org.infinispan.persistence.file.SingleFileStore.start(SingleFileStore.java:135)
    at org.infinispan.persistence.manager.PersistenceManagerImpl.start(PersistenceManagerImpl.java:141)
    ... 78 more
Caused by: java.io.IOException: Unsupported protocol version 22
    at org.jboss.marshalling.river.RiverUnmarshaller.start(RiverUnmarshaller.java:1249)
    at org.infinispan.commons.marshall.jboss.AbstractJBossMarshaller.startObjectInput(AbstractJBossMarshaller.java:128)
    at org.infinispan.marshall.core.VersionAwareMarshaller.startObjectInput(VersionAwareMarshaller.java:142)
    at org.infinispan.marshall.core.VersionAwareMarshaller.objectFromByteBuffer(VersionAwareMarshaller.java:98)
    at org.infinispan.commons.marshall.AbstractDelegatingMarshaller.objectFromByteBuffer(AbstractDelegatingMarshaller.java:80)
    at org.infinispan.persistence.file.SingleFileStore.rebuildIndex(SingleFileStore.java:212)
    at org.infinispan.persistence.file.SingleFileStore.start(SingleFileStore.java:126)
    ... 79 more

这就是我的缓存配置的样子:

代码语言:javascript
复制
<distributed-cache name="singletons">
        <versioning scheme="SIMPLE"/>
            <persistence passivation="false" >
                <file-store
                    path="${infinispan.dir}/broker-ds/singletons"
                    fetch-state="true" shared="true" preload="true" />
            </persistence>
        </distributed-cache>

有什么不对劲的线索吗?我正在使用Infinispan8.1版本。

更新:

我没有使用基于共享文件的存储,而是使用了基于JDBC的共享存储,一切都很好。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-11-02 08:50:04

不幸的是,您还不能(还)使用多个节点之间共享的文件存储。要么使用一个专用于每个节点的目录,要么使用一个能够共享的存储(jdbc、jpa、cassandra)。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40373530

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档