Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/315.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 从Spring应用程序连接到Cassandra池时出现问题_Java_Spring_Spring Boot_Cassandra_Nosql - Fatal编程技术网

Java 从Spring应用程序连接到Cassandra池时出现问题

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),一切都正常工作。但一旦我停止

我希望,有人真的能帮上忙,因为我目前一直在努力与卡桑德拉ATM合作

我的设置: 对于开发,我有一个最小的Cassandra 3.0.4集群,它有两个节点(一个在我的工作机器上,一个在VM中)。通常只有本地的一个启动并运行。 我使用最新的Java驱动程序版本3.0.0连接到池

My cassandra.yaml包含每个节点的IP的
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初始化了一个键空间-我读到了一些消息,这个数目不应该超过节点的数目(我猜它在文档中的某个地方,但我再也没有链接了)。。。这可能是一个原因吗?

一个微不足道的人,似乎没有人知道这种问题。在互联网上进行了几次尝试和搜索之后(在那里我几乎没有发现关于这个特定问题的任何信息),我几乎放弃了这个想法

但是。

然后我注意到两件事:

  • 我的测试键空间的复制因子是3,而我只有两个节点。不太明智
  • 如果我仔细观察这个异常,我会发现,这是一个警告,而不是致命的错误
  • 那又怎样

    我仍然能够连接到集群并实际查询它,但总是因为这个异常而过早放弃

    几乎“无事生非”

    目前一切正常,我可以进一步开发我的应用程序。还可以了解很多关于这个高可用性NoSQL数据库的信息,以及它与“经典”关系数据库的不同之处,即使查询语言有很多相似之处。 真令人兴奋

    所以:很抱歉这么大惊小怪

    干杯,
    丹尼尔

    自从我面临同样的问题以来,我试着读了更多关于你所面临的问题的书。我有一个由4个节点组成的集群,其中一个节点遇到了问题。为了避免出现此错误,我执行了以下两个步骤-

  • 从我在java类中创建cassandra集群时传递的节点列表中删除了特定的失败节点
  • 已从cassandra中的群集配置中删除该节点#除非节点已从群集中删除,否则1不会进行任何更改
    可逆地,如果节点关闭且无法启动,则实际上应该修复该节点。如果不需要该节点,则应将其从集群中移除,并且在启动服务时,该节点不得作为警告弹出。我想,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,以及它来自何处?你能告诉我我做错了什么吗?