无效查询异常:未配置表模式键空间。

26

我正在尝试配置Spring Data与Cassandra。但是,当我的应用程序在Tomcat上部署时出现以下错误。

当我检查连接时,它可用于给定的端口(127.0.0.1:9042)。我已经包含了下面的堆栈跟踪和Spring配置。有谁知道这个错误的原因吗?

完整的堆栈跟踪:

2015-12-06 17:46:25 ERROR web.context.ContextLoader:331 - Context initialization failed
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'cassandraSession': Invocation of init method failed; nested exception is com.datastax.driver.core.exceptions.NoHostAvailableException: All host(s) tried for query failed (tried: /127.0.0.1:9042 (com.datastax.driver.core.exceptions.InvalidQueryException: unconfigured table schema_keyspaces))
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1572)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:539)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:476)
    at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:303)
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230)
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:299)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:194)
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:736)
    at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:759)
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:480)
    at org.springframework.web.context.ContextLoader.configureAndRefreshWebApplicationContext(ContextLoader.java:434)
    at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:306)
    at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:106)
    at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4994)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5492)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:901)
    at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:877)
    at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:649)
    at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:1245)
    at org.apache.catalina.startup.HostConfig$DeployDirectory.run(HostConfig.java:1895)
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
    at java.util.concurrent.FutureTask.run(FutureTask.java:266)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    at java.lang.Thread.run(Thread.java:745)
Caused by: com.datastax.driver.core.exceptions.NoHostAvailableException: All host(s) tried for query failed (tried: /127.0.0.1:9042 (com.datastax.driver.core.exceptions.InvalidQueryException: unconfigured table schema_keyspaces))
    at com.datastax.driver.core.ControlConnection.reconnectInternal(ControlConnection.java:223)
    at com.datastax.driver.core.ControlConnection.connect(ControlConnection.java:78)
    at com.datastax.driver.core.Cluster$Manager.init(Cluster.java:1230)
    at com.datastax.driver.core.Cluster.init(Cluster.java:157)
    at com.datastax.driver.core.Cluster.connect(Cluster.java:245)
    at com.datastax.driver.core.Cluster.connect(Cluster.java:278)
    at org.springframework.cassandra.config.CassandraCqlSessionFactoryBean.afterPropertiesSet(CassandraCqlSessionFactoryBean.java:82)
    at org.springframework.data.cassandra.config.CassandraSessionFactoryBean.afterPropertiesSet(CassandraSessionFactoryBean.java:43)

===================================================================

Spring配置:

<?xml version="1.0" encoding="UTF-8"?>
<beans:beans ...>

    <cassandra:cluster id="cassandraCluster"
                       contact-points="127.0.0.1" port="9042" />
    <cassandra:converter />

    <cassandra:session id="cassandraSession" cluster-ref="cassandraCluster"
                       keyspace-name="blood" />

    <cassandra:template id="cqlTemplate" />


    <cassandra:repositories base-package="com.blood.dao.nosql" />
    <cassandra:mapping entity-base-packages="com.blood.domain.nosql" />

</beans:beans>

3
你最终解决了这个问题吗?我也遇到了同样的困扰。 - Will Faithfull
1
@Will,没有。我猜这是版本不兼容的原因。 - Harsha
@Harsha 你好!你最终解决了这个问题吗?三年后了? - dehasi
2个回答

24
问题在于,截至我撰写此文的2015年12月,Spring Data Cassandra还不支持Cassandra 3.x。以下是与freenode上的spring频道之一开发者的对话摘录:

[13:49] <_amicable> 大家好,有谁知道spring data cassandra是否支持cassandra 3.x?所有依赖和datastax驱动程序似乎都是2.x

[13:49] <@_ollie> amicable:近期内不支持。

[13:49] <_amicable> _ollie:谢谢。

[13:50] <_amicable> 我会去看看2.x与3.x相对优劣的;)

[13:51] <@_ollie> SD Cassandra是社区项目(目前为止),其进展高度取决于开发人员实际花费的时间。

[13:51] <@_ollie> 我们将有人于2016年2月加入团队,使该项目更加紧密地与核心Spring Data项目相关联。


5

看起来你正在使用旧版驱动程序与Cassandra 3.0一起使用。Cassandra 3.0更改了其内部架构元数据表示,只有最新的驱动程序才能解析此元数据。

请使用Java Cassandra驱动程序3.0.0-alpha5连接到Cassandra 3.0。


1
谢谢Adam,但是这并没有起作用。我正在使用“spring-data-cassandra”Maven依赖项,它在内部引用较低版本的Cassandra驱动程序。即使我添加了Cassandra 3.0.0-alpha5,它仍然会在Spring中抛出错误。 - Harsha
3
记录一下,java.lang.NoSuchMethodError: com.datastax.driver.core.DataType.asJavaClass()Ljava/lang/Class;这样的错误是常见的。 - OrangeDog
1
注意:这在Datastax升级文档3.0.0中提到(已发布),请参见http://datastax.github.io/java-driver/upgrade_guide/。这是文档中的注释:“现在必须直接在TypeCodec上调用这些方法。要解析特定数据类型的TypeCodec实例,请使用CodecRegistry#codecFor。”希望它能帮助任何试图自行修复的人。其他破坏的API也在此文档中提到。 - Shriram M.
他们将上述的升级指南移至:http://docs.datastax.com/en/developer/java-driver/3.2/upgrade_guide/。 - Dex Stakker

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接