首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >哈泽尔广播:无法进行远程调用: com.hazelcast.map.impl.operation.GetOperation

哈泽尔广播:无法进行远程调用: com.hazelcast.map.impl.operation.GetOperation
EN

Stack Overflow用户
提问于 2020-06-08 15:37:16
回答 1查看 915关注 0票数 3

我们在我们的项目中使用Hazelcast 3.10.4。还启用了第二级缓存。有时,我们会得到下面提到的一个异常:3个Hazelcast节点:同一台机器上的两个节点和不同机器上的一个节点。但是网络是一样的。异常发生在两个节点之一。不在另一台机器上运行的节点上。

我们得到了这个,当我们启动服务器,然后做一些操作。

案例:考虑缓存-1和缓存-2都是分布式哈泽尔卡斯特缓存( hazelcast IMap)。在服务器启动时,缓存-1被完全初始化.一旦服务器启动和运行,缓存-1仅用于获取数据-没有更新,没有重新加载发生。Cache-1包含处理所需的所有数据。比方说,Cache-1包含在不同级别上定义的所有系统配置,一旦系统启动,用户就不会改变这些配置。这个缓存分布在3个节点上。

缓存-2在服务器启动时被部分初始化.一旦服务器启动并运行,系统将修改Cache-2 :从缓存中删除数据,修改缓存中的数据,根据Cache-1中存在的某些配置(部分按需加载)为缓存中不存在的源加载数据。

请注意:在服务器启动时,在缓存-2中加载数据时会发生相同的检查.但服务器启动时没有出现故障。

当系统试图从Cache-1检索值时,我们会遇到异常:

代码语言:javascript
复制
java.lang.IllegalThreadStateException: Thread[hz._hzInstance_1_tpt-val-js-master.partition-operation.thread-1,5,main] cannot make remote call: com.hazelcast.map.impl.operation.GetOperation{serviceName='hz:impl:mapService', identityHash=1023062798, partitionId=234, replicaIndex=0, callId=0, invocationTime=-1 (1969-12-31 23:59:59.999), waitTimeout=-1, callTimeout=1800000, name=ConfigParamMap}
at com.hazelcast.spi.impl.operationservice.impl.Invocation.invoke0(Invocation.java:523)
at com.hazelcast.spi.impl.operationservice.impl.Invocation.invoke(Invocation.java:215)
at com.hazelcast.spi.impl.operationservice.impl.InvocationBuilderImpl.invoke(InvocationBuilderImpl.java:60)
at com.hazelcast.map.impl.proxy.MapProxySupport.invokeOperation(MapProxySupport.java:424)
at com.hazelcast.map.impl.proxy.MapProxySupport.getInternal(MapProxySupport.java:347)
at com.hazelcast.map.impl.proxy.NearCachedMapProxyImpl.getInternal(NearCachedMapProxyImpl.java:114)
at com.hazelcast.map.impl.proxy.MapProxyImpl.get(MapProxyImpl.java:116)
at com.tpt.atlant.grid.dao.hazelcast.DataHazelcastDAO.getData(DataHazelcastDAO.java:84)
at com.tpt.atlant.configparam.service.ConfigParamServiceImpl.getConfigParam(ConfigParamServiceImpl.java:33)
at com.tpt.atlant.configparam.service.ConfigParamServiceImpl.getBooleanValue(ConfigParamServiceImpl.java:52)
at com.tpt.atlant.configparam.service.ConfigParamServiceImpl$$FastClassBySpringCGLIB$$b698afe3.invoke(<generated>)
at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:204)
at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:720)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:157)
at org.springframework.cache.interceptor.CacheInterceptor$1.invoke(CacheInterceptor.java:52)
at org.springframework.cache.interceptor.CacheAspectSupport.invokeOperation(CacheAspectSupport.java:345)
at org.springframework.cache.interceptor.CacheAspectSupport.execute(CacheAspectSupport.java:414)
at org.springframework.cache.interceptor.CacheAspectSupport.execute(CacheAspectSupport.java:327)
at org.springframework.cache.interceptor.CacheInterceptor.invoke(CacheInterceptor.java:61)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:655)
at com.tpt.atlant.configparam.service.ConfigParamServiceImpl$$EnhancerBySpringCGLIB$$401b9858.getBooleanValue(<generated>)
at com.tpt.trade.grid.dao.loader.jdbi.TermDataJDBILoader.isBasisPl(TermDataJDBILoader.java:411)
at com.tpt.trade.grid.dao.loader.jdbi.TermDataJDBILoader.prepareInClauseFromList(TermDataJDBILoader.java:385)
at com.tpt.trade.grid.dao.loader.jdbi.TermDataJDBILoader.getCmdtyInstruments(TermDataJDBILoader.java:381)
at com.tpt.trade.grid.dao.loader.jdbi.TermDataJDBILoader.loadTermAttributes(TermDataJDBILoader.java:353)
at com.tpt.trade.grid.dao.loader.jdbi.TermDataJDBILoader.load(TermDataJDBILoader.java:263)
at com.tpt.trade.grid.dao.loader.jdbi.TermDataJDBILoader.load(TermDataJDBILoader.java:1)
at com.tpt.trade.grid.dao.loader.jdbi.TermDataJDBILoader$$FastClassBySpringCGLIB$$f032653.invoke(<generated>)
at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:204)
at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:651)
at com.tpt.trade.grid.dao.loader.jdbi.TermDataJDBILoader$$EnhancerBySpringCGLIB$$b6e9411d.load(<generated>)
at com.tpt.atlant.grid.dao.loader.hazelcast.HazelcastMapLoader.load(HazelcastMapLoader.java:62)
at com.tpt.atlant.grid.dao.loader.hazelcast.HazelcastMapLoader.load(HazelcastMapLoader.java:33)
at com.tpt.atlant.grid.util.hazelcast.SpringContextMapLoaderFactory$DynamicSpringContectLoaderResolver.load(SpringContextMapLoaderFactory.java:223)
at com.tpt.atlant.grid.util.hazelcast.SpringContextMapLoaderFactory$DynamicSpringContectLoaderResolver.load(SpringContextMapLoaderFactory.java:179)
at com.hazelcast.map.impl.MapStoreWrapper.load(MapStoreWrapper.java:165)
at com.hazelcast.map.impl.mapstore.writethrough.WriteThroughStore.load(WriteThroughStore.java:72)
at com.hazelcast.map.impl.mapstore.writethrough.WriteThroughStore.load(WriteThroughStore.java:28)
at com.hazelcast.map.impl.recordstore.DefaultRecordStore.loadRecordOrNull(DefaultRecordStore.java:415)
at com.hazelcast.map.impl.recordstore.DefaultRecordStore.get(DefaultRecordStore.java:626)
at com.hazelcast.map.impl.operation.GetOperation.run(GetOperation.java:41)
at com.hazelcast.spi.Operation.call(Operation.java:148)
at com.hazelcast.spi.impl.operationservice.impl.OperationRunnerImpl.call(OperationRunnerImpl.java:202)
at com.hazelcast.spi.impl.operationservice.impl.OperationRunnerImpl.run(OperationRunnerImpl.java:191)
at com.hazelcast.spi.impl.operationexecutor.impl.OperationThread.process(OperationThread.java:120)
at com.hazelcast.spi.impl.operationexecutor.impl.OperationThread.run(OperationThread.java:100)
at ------ submitted from ------.(Unknown Source)
at com.hazelcast.spi.impl.operationservice.impl.InvocationFuture.resolve(InvocationFuture.java:127)
at com.hazelcast.spi.impl.operationservice.impl.InvocationFuture.resolveAndThrowIfException(InvocationFuture.java:79)
at com.hazelcast.spi.impl.AbstractInvocationFuture.get(AbstractInvocationFuture.java:162)
at com.hazelcast.map.impl.proxy.MapProxySupport.invokeOperation(MapProxySupport.java:425)
at com.hazelcast.map.impl.proxy.MapProxySupport.getInternal(MapProxySupport.java:347)
at com.hazelcast.map.impl.proxy.NearCachedMapProxyImpl.getInternal(NearCachedMapProxyImpl.java:114)
at com.hazelcast.map.impl.proxy.MapProxyImpl.get(MapProxyImpl.java:116)
at com.tpt.trade.grid.dao.hazelcast.TermDataNumberHazelcastDAO.getTermData(TermDataNumberHazelcastDAO.java:54)
at com.tpt.valuation.position.grid.value.action.BatchTermValueAction.execute(BatchTermValueAction.java:107)

抛出此异常的Hazelcast代码正在检查:操作键的分区id是否与分区线程id匹配。如果没有,则抛出异常。还有很多其他的代码。

谁能告诉我这件事的根源吗?如果缓存设计有问题,那么每次都会发生这种异常。无法在具有两个或三个节点的开发人员机器上复制。但有时可以在测试机器上重新生产。

更新:添加了完整的堆栈跟踪。我们实现了MapLoader来将数据加载到缓存中。

原因可能是:在写入操作期间,系统试图从具有不同密钥的不同缓存中访问数据。

这个逻辑是一岁,工作良好。最近,我们只在测试环境中才开始获得此异常。

EN

回答 1

Stack Overflow用户

发布于 2020-06-13 08:30:07

我们能够复制这个问题。

我们正在维护二级缓存。因为我们在处理过程中将cache1键的数据保存在二级缓存中,所以这个问题并不是每次都会发生。我们刚刚清除了每个cache2.get(key)之前的第二级缓存,以解决复制问题。

如果在cache2哈泽尔广播映射中找不到密钥数据,则系统将调用MapLoader的加载方法。在这里,分区线程进入图片,操作是通过操作写入的。

在Cache2 MapLoader的加载方法中,我们尝试从具有不同密钥类型的cache-1中访问数据。由于Cache-1和Cache-2的关键类型不同,出现分区不匹配,从而导致“无法进行远程调用”异常。

问题:如果真的需要这样做的话,有没有办法做到这一点?

解决方案1:我们使用IExecutorService在Cache2 MapLoader的加载方法中访问Cache1的值。这很好用。但这可能会增加数据加载时间,因为涉及到额外的线程。

解决方案-2:为Cache1设置备份计数=节点数-1。这样,我们在每个节点上都有地图副本。这种异常永远不会发生,因为在运行时(每周一次),Cache1中的任何更改都会发生非常少的更改。记录的数量也不超过1000。

还有其他方法来实现这一点吗?

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

https://stackoverflow.com/questions/62265785

复制
相关文章

相似问题

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