Java 从Spring应用程序连接到Cassandra池时出现问题
我希望,有人真的能帮上忙,因为我目前一直在努力与卡桑德拉ATM合作 我的设置: 对于开发,我有一个最小的Cassandra 3.0.4集群,它有两个节点(一个在我的工作机器上,一个在VM中)。通常只有本地的一个启动并运行。 我使用最新的Java驱动程序版本3.0.0连接到池 My cassandra.yaml包含每个节点的IP的Java 从Spring应用程序连接到Cassandra池时出现问题,java,spring,spring-boot,cassandra,nosql,Java,Spring,Spring Boot,Cassandra,Nosql,我希望,有人真的能帮上忙,因为我目前一直在努力与卡桑德拉ATM合作 我的设置: 对于开发,我有一个最小的Cassandra 3.0.4集群,它有两个节点(一个在我的工作机器上,一个在VM中)。通常只有本地的一个启动并运行。 我使用最新的Java驱动程序版本3.0.0连接到池 My cassandra.yaml包含每个节点的IP的rpc\u地址和listen\u地址。种子是我主要的工作机器 我的问题是: 从cqlsh(在任何时候)以及当两个节点都在运行时(从Java),一切都正常工作。但一旦我停止
rpc\u地址
和listen\u地址
。种子是我主要的工作机器
我的问题是:
从cqlsh(在任何时候)以及当两个节点都在运行时(从Java),一切都正常工作。但一旦我停止VM中的应用程序,我基于Spring的应用程序就会在启动过程中抛出错误:
2016-03-29 09:05:33.515 | INFO | main | com.datastax.driver.core.NettyUtil :83 | Did not find Netty's native epoll transport in the classpath, defaulting to NIO.
2016-03-29 09:05:34.147 | INFO | main | com.datastax.driver.core.policies.DCAwareRoundRobinPolicy :95 | Using data-center name 'datacenter1' for DCAwareRoundRobinPolicy (if this is incorrect, please provide the correct datacenter name with DCAwareRoundRobinPolicy constructor)
2016-03-29 09:05:34.149 | INFO | main | com.datastax.driver.core.Cluster$Manager :1475 | New Cassandra host /10.20.30.74:9042 added
2016-03-29 09:05:34.149 | INFO | main | com.datastax.driver.core.Cluster$Manager :1475 | New Cassandra host /10.20.30.77:9042 added
2016-03-29 09:05:34.150 | INFO | main | my_company.cassandra.dao.impl.CassandraDaoImpl :55 | Connected to cluster: TestCaseCluster
2016-03-29 09:05:34.151 | INFO | main | my_company.cassandra.dao.impl.CassandraDaoImpl :57 | Datacenter: datacenter1; Host: /10.20.30.74; Rack: rack1, State: UP|true
2016-03-29 09:05:34.151 | INFO | main | my_company.cassandra.dao.impl.CassandraDaoImpl :57 | Datacenter: datacenter1; Host: /10.20.30.77; Rack: rack1, State: UP|true
2016-03-29 09:05:34.220 | WARN | luster1-nio-worker-2 | com.datastax.driver.core.SessionManager$7 :378 | Error creating pool to /10.20.30.77:9042
com.datastax.driver.core.exceptions.ConnectionException: [/10.20.30.77] Pool was closed during initialization
at com.datastax.driver.core.HostConnectionPool$2.onSuccess(HostConnectionPool.java:149) [cassandra-driver-core-3.0.0.jar:?]
at com.datastax.driver.core.HostConnectionPool$2.onSuccess(HostConnectionPool.java:135) [cassandra-driver-core-3.0.0.jar:?]
at com.google.common.util.concurrent.Futures$4.run(Futures.java:1181) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.MoreExecutors$SameThreadExecutorService.execute(MoreExecutors.java:297) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.ExecutionList.executeListener(ExecutionList.java:156) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.ExecutionList.execute(ExecutionList.java:145) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.AbstractFuture.set(AbstractFuture.java:185) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.Futures$CombinedFuture.setOneValue(Futures.java:1626) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.Futures$CombinedFuture.access$400(Futures.java:1470) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.Futures$CombinedFuture$2.run(Futures.java:1548) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.MoreExecutors$SameThreadExecutorService.execute(MoreExecutors.java:297) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.ExecutionList.executeListener(ExecutionList.java:156) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.ExecutionList.execute(ExecutionList.java:145) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.AbstractFuture.set(AbstractFuture.java:185) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.Futures$FallbackFuture$1$1.onSuccess(Futures.java:475) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.Futures$4.run(Futures.java:1181) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.MoreExecutors$SameThreadExecutorService.execute(MoreExecutors.java:297) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.Futures$ImmediateFuture.addListener(Futures.java:102) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.Futures.addCallback(Futures.java:1184) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.Futures$FallbackFuture$1.onFailure(Futures.java:472) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.Futures$4.run(Futures.java:1172) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.MoreExecutors$SameThreadExecutorService.execute(MoreExecutors.java:297) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.ExecutionList.executeListener(ExecutionList.java:156) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.ExecutionList.execute(ExecutionList.java:145) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.AbstractFuture.setException(AbstractFuture.java:202) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.Futures$FallbackFuture$1$1.onFailure(Futures.java:483) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.Futures$4.run(Futures.java:1172) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.MoreExecutors$SameThreadExecutorService.execute(MoreExecutors.java:297) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.ExecutionList.executeListener(ExecutionList.java:156) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.ExecutionList.add(ExecutionList.java:101) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.AbstractFuture.addListener(AbstractFuture.java:170) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.Futures.addCallback(Futures.java:1184) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.Futures$FallbackFuture$1.onFailure(Futures.java:472) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.Futures$4.run(Futures.java:1172) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.MoreExecutors$SameThreadExecutorService.execute(MoreExecutors.java:297) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.ExecutionList.executeListener(ExecutionList.java:156) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.ExecutionList.execute(ExecutionList.java:145) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.AbstractFuture.setException(AbstractFuture.java:202) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.Futures$ChainingListenableFuture.run(Futures.java:857) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.MoreExecutors$SameThreadExecutorService.execute(MoreExecutors.java:297) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.ExecutionList.executeListener(ExecutionList.java:156) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.ExecutionList.execute(ExecutionList.java:145) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.AbstractFuture.setException(AbstractFuture.java:202) [guava-16.0.1.jar:?]
at com.google.common.util.concurrent.SettableFuture.setException(SettableFuture.java:68) [guava-16.0.1.jar:?]
at com.datastax.driver.core.Connection$1.operationComplete(Connection.java:157) [cassandra-driver-core-3.0.0.jar:?]
at com.datastax.driver.core.Connection$1.operationComplete(Connection.java:140) [cassandra-driver-core-3.0.0.jar:?]
at io.netty.util.concurrent.DefaultPromise.notifyListener0(DefaultPromise.java:680) [netty-common-4.0.33.Final.jar:4.0.33.Final]
at io.netty.util.concurrent.DefaultPromise.notifyListeners0(DefaultPromise.java:603) [netty-common-4.0.33.Final.jar:4.0.33.Final]
at io.netty.util.concurrent.DefaultPromise.notifyListeners(DefaultPromise.java:563) [netty-common-4.0.33.Final.jar:4.0.33.Final]
at io.netty.util.concurrent.DefaultPromise.tryFailure(DefaultPromise.java:424) [netty-common-4.0.33.Final.jar:4.0.33.Final]
at io.netty.channel.nio.AbstractNioChannel$AbstractNioUnsafe.fulfillConnectPromise(AbstractNioChannel.java:276) [netty-transport-4.0.33.Final.jar:4.0.33.Final]
at io.netty.channel.nio.AbstractNioChannel$AbstractNioUnsafe.finishConnect(AbstractNioChannel.java:292) [netty-transport-4.0.33.Final.jar:4.0.33.Final]
at io.netty.channel.nio.NioEventLoop.processSelectedKey(NioEventLoop.java:528) [netty-transport-4.0.33.Final.jar:4.0.33.Final]
at io.netty.channel.nio.NioEventLoop.processSelectedKeysOptimized(NioEventLoop.java:468) [netty-transport-4.0.33.Final.jar:4.0.33.Final]
at io.netty.channel.nio.NioEventLoop.processSelectedKeys(NioEventLoop.java:382) [netty-transport-4.0.33.Final.jar:4.0.33.Final]
at io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:354) [netty-transport-4.0.33.Final.jar:4.0.33.Final]
at io.netty.util.concurrent.SingleThreadEventExecutor$2.run(SingleThreadEventExecutor.java:112) [netty-common-4.0.33.Final.jar:4.0.33.Final]
at java.lang.Thread.run(Thread.java:745) [?:1.8.0_74]
在本例中,我发现以下几行很有趣:
Datacenter: datacenter1; Host: /10.20.30.77; Rack: rack1, State: UP|true
因为这是上面提到的虚拟机,所以它实际上已关闭:
Datacenter: datacenter1
=======================
Status=Up/Down
|/ State=Normal/Leaving/Joining/Moving
-- Address Load Tokens Owns (effective) Host ID Rack
DN 10.20.30.77 89.12 KB 256 100.0% 197f6f0f-b820-4ab8-b7ef-bcc8773a345c rack1
UN 10.20.30.74 96.26 KB 256 100.0% db7d053b-f8d1-4a59-9cb2-3abf54b24687 rack1
根据nodetools status
中的摘录,其中DN应表示“停机”和“正常”。
据我所知,Java驱动程序没有识别出第二个节点已关闭,仍然尝试连接到它,因为它位于(可用)节点列表中
因为驱动程序版本和Cassandra版本的组合,这可能是一个不兼容的问题吗?但我认为,它们是兼容的:
如果您需要更多信息,请询问。我将相应地更新此文本
谢谢和问候
丹尼尔
edit1:我已经用复制类SimpleStrategy和factor 3初始化了一个键空间-我读到了一些消息,这个数目不应该超过节点的数目(我猜它在文档中的某个地方,但我再也没有链接了)。。。这可能是一个原因吗?一个微不足道的人,似乎没有人知道这种问题。在互联网上进行了几次尝试和搜索之后(在那里我几乎没有发现关于这个特定问题的任何信息),我几乎放弃了这个想法 但是。 然后我注意到两件事:
丹尼尔自从我面临同样的问题以来,我试着读了更多关于你所面临的问题的书。我有一个由4个节点组成的集群,其中一个节点遇到了问题。为了避免出现此错误,我执行了以下两个步骤-
可逆地,如果节点关闭且无法启动,则实际上应该修复该节点。如果不需要该节点,则应将其从集群中移除,并且在启动服务时,该节点不得作为警告弹出。我想,Cassandra需要一个永久性的修复这个问题(警告),因为如果节点关闭,就不需要创建会话。另一方面,这只是一个警告,如果您的应用程序没有任何可疑之处,则可以忽略。'nodetool status'显示您的cassandra节点已关闭,要解决您的问题,您必须启动节点。您好,我遇到了类似的问题。我的集群由下面的thredd节点spring.data.cassandra.contact points=10.202.82.25,10.180.19.157,10.180.12.222组成,但我正在错误堆栈[/10.183.74.152:9042]下面池在初始化期间关闭新建Cassandra主机/10.202.82.25:9042添加了新Cassandra主机/10.180.12.222:9042添加了新Cassandra主机/10.180.19.157:9042添加了新Cassandra主机/10.183.74.152:9042将创建池的错误添加到/10.183.74.152:9042 driver.core.exceptions.ConnectionException:[/10.183.74.152:9042]池在初始化过程中关闭不确定它为什么会得到另一个节点,即10.183.74.152,以及它来自何处?你能告诉我我做错了什么吗?