com.datastax.driver.core.exceptions.InvalidQueryException:未配置的表 schema_keyspaces
Posted
技术标签:
【中文标题】com.datastax.driver.core.exceptions.InvalidQueryException:未配置的表 schema_keyspaces【英文标题】:com.datastax.driver.core.exceptions.InvalidQueryException: unconfigured table schema_keyspaces 【发布时间】:2016-03-11 02:23:35 【问题描述】:我正在尝试使用 cassandra 配置 spring 数据。 但是当我的应用程序在 tomcat 中部署时,出现以下错误。
当我检查连接时,它可用于给定端口。 (127.0.0.1:9042)。我在下面包含堆栈跟踪和弹簧配置。 有人知道这个错误吗?
完整的堆栈跟踪:
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)
================================================ =====================
弹簧配置:
<?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>
【问题讨论】:
你最后解决了吗?我遇到了同样的问题。 @Will,不,我没有。我也猜这是由于版本不兼容。 @Harsha 你好!你最后弄清楚了吗? 3年后? 【参考方案1】:问题在于 Spring Data Cassandra(截至 2015 年 12 月我写这篇文章时)不提供对 Cassandra 3.x 的支持。以下是与 freenode 上 #spring 频道中一位开发人员的对话摘录:
[13:49] <_amicable>大家好,有人知道spring data cassandra是否支持cassandra 3.x吗?所有依赖项和 datastax 驱动程序似乎都是 2.x
[13:49] 友好:近期不会。
[13:49] <_amicable> _ollie:谢谢。
[13:50] <_amicable> 然后我会去看看 2.x 与 3.x 的相对优点 ;)
[13:51] SD Cassandra 是一个社区项目(到目前为止),它的进展很大程度上取决于开发人员实际上可以花多少时间。
[13:51] 我们将在 2016 年 2 月派人加入团队,以使该项目与核心 Spring Data 项目更紧密地保持一致。
【讨论】:
【参考方案2】:您似乎在使用旧版本的驱动程序和 Cassandra 3.0。 Cassandra 3.0 更改了其内部架构元数据表示,只有最新的驱动程序才能解析此元数据。
使用 Java Cassandra 驱动程序3.0.0-alpha5 连接到 Cassandra 3.0。
【讨论】:
谢谢亚当,但这不起作用。我正在使用“spring-data-cassandra”maven 依赖项,它在内部引用较低版本的 Cassandra 驱动程序。即使我添加了 cassandra 3.0.0-alpha5,它也会在 spring 中引发错误。 备案,java.lang.NoSuchMethodError: com.datastax.driver.core.DataType.asJavaClass()Ljava/lang/Class;
等错误
注意:这在 Datastax 3.0.0(已发布)的升级文档中提到了这里datastax.github.io/java-driver/upgrade_guide。这是文档中的注释“现在必须直接在 TypeCodec 上调用这些方法。要解析特定数据类型的 TypeCodec 实例,请使用 CodecRegistry#codecFor。”希望它可以帮助任何试图自己修复它的人。本文档中还提到了其他中断的 API。
他们将上述升级指南移至:docs.datastax.com/en/developer/java-driver/3.2/upgrade_guide以上是关于com.datastax.driver.core.exceptions.InvalidQueryException:未配置的表 schema_keyspaces的主要内容,如果未能解决你的问题,请参考以下文章
com.datastax.driver.core.exceptions.InvalidQueryException:未配置的表用户”
com.datastax.driver.core.exceptions.InvalidQueryException:未配置的表 schema_keyspaces
java.lang.NoClassDefFoundError:无法初始化类 com.datastax.driver.core.Cluster
com.datastax.driver.core.TransportException: [/xx.xxx.x.xxx:9042] 无法连接
引起:com.datastax.driver.core.exceptions.InvalidQueryException:预计日期为 8 或 0 字节长 (13)
为啥 Spark Cassandra 连接器因 NoSuchMethodError: com.datastax.driver.core.TableMetadata.getIndexes()Ljava/