我正在使用hazelcast:
spring-integration-hazelcast:1.0.0.RELEASE
hazelcast-all:3.12.4
一切正常:)
由于遇到了一些问题,我试图更新到最新版本,所以:
hazelcast 3.12.6
spring-integration-hazelcast
2.0.0.RELEASE
但是我的应用程序甚至没有启动,我得到了:
cluster-manager_1 | com.hazelcast.core.HazelcastException: CP Subsystem is not enabled!
cluster-manager_1 | at com.hazelcast.cp.internal.RaftInvocationManager.completeExceptionallyIfCPSubsystemNotAvailable(RaftInvocationManager.java:113)
cluster-manager_1 | at com.hazelcast.cp.internal.RaftInvocationManager.invoke(RaftInvocationManager.java:186)
cluster-manager_1 | at com.hazelcast.cp.internal.RaftService.getGroupInfoForProxy(RaftService.java:752)
cluster-manager_1 | at com.hazelcast.cp.internal.RaftService.createRaftGroupForProxy(RaftService.java:704)
cluster-manager_1 | at com.hazelcast.cp.internal.datastructures.lock.RaftLockService.doCreateProxy(RaftLockService.java:193)
cluster-manager_1 | at com.hazelcast.cp.internal.datastructures.lock.RaftLockService.createProxy(RaftLockService.java:177)
cluster-manager_1 | at com.hazelcast.cp.internal.datastructures.lock.RaftLockService.createProxy(RaftLockService.java:43)
cluster-manager_1 | at com.hazelcast.cp.internal.CPSubsystemImpl.getLock(CPSubsystemImpl.java:76)
cluster-manager_1 | at org.springframework.integration.hazelcast.HazelcastLocalInstanceRegistrar.syncConfigurationMultiMap(HazelcastLocalInstanceRegistrar.java:99)
cluster-manager_1 | at org.springframework.integration.hazelcast.HazelcastLocalInstanceRegistrar.afterSingletonsInstantiated(HazelcastLocalInstanceRegistrar.java:86)
cluster-manager_1 | at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:896)
cluster-manager_1 | at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:878)
cluster-manager_1 | at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:550)
cluster-manager_1 | at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:141)
cluster-manager_1 | at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:747)
cluster-manager_1 | at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:397)
cluster-manager_1 | at org.springframework.boot.SpringApplication.run(SpringApplication.java:315)
cluster-manager_1 | at com.btnty.citm.clustermanager.springboot.ClusterManagerApplication.main(ClusterManagerApplication.java:49)
cluster-manager_1 | at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
cluster-manager_1 | at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
cluster-manager_1 | at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
cluster-manager_1 | at java.lang.reflect.Method.invoke(Method.java:498)
cluster-manager_1 | at org.springframework.boot.loader.MainMethodRunner.run(MainMethodRunner.java:48)
cluster-manager_1 | at org.springframework.boot.loader.Launcher.launch(Launcher.java:87)
cluster-manager_1 | at org.springframework.boot.loader.Launcher.launch(Launcher.java:51)
cluster-manager_1 | at org.springframework.boot.loader.JarLauncher.main(JarLauncher.java:52)
但是为什么呢? :-(“问题”不是hazelcast 3.12.6
,因为它可以正常工作
spring-integration-hazelcast 1.0.0.RELEASE
。但是从spring-integration-hazelcast 1.0.0.RELEASE
更改为2.0.0.RELEASE
会触发此错误。
[1]
implementation ("org.springframework.boot:spring-boot-starter-web:2.2.5.RELEASE")
implementation ("org.springframework.integration:spring-integration-hazelcast:1.0.0.RELEASE")
implementation "com.hazelcast:hazelcast-all:3.12.4"
compile group: 'org.springframework.integration', name: 'spring-integration-core', version: '5.2.1.RELEASE'
答案 0 :(得分:1)
问题是spring-integration
模块使用Hazelcast CP Subsystem(在CPSubsystemImpl.getLock()
中),该模块在Hazelcast中默认为禁用。
您可以使用以下Hazelcast配置启用它:
@Bean
HazelcastInstance hazelcastInstance() {
Config config = new Config();
config.getCPSubsystemConfig().setCPMemberCount(3);
return Hazelcast.newHazelcastInstance(config);
}
请注意,您的群集中至少应有3个Hazelcast成员。