2015-12-09 109 views
2

已安装CassandraVM-2.0.7.ova。哪个版本的昆德拉能够与这个版本的Cassandra正常工作?面对太多试图获取这些信息的问题。可能是我的配置错误。这些信息是否记录在某个地方?在persistence.xml中

<dependency> <groupId>com.impetus.kundera.client</groupId> <artifactId>kundera-cassandra</artifactId> <version>3.2</version> </dependency>昆德拉版本兼容性文档

属性如下:

我试着用这个Maven的依赖

<persistence-unit name="cassandra_pu"> 
    <provider>com.impetus.kundera.KunderaPersistence</provider> 
    <properties> 
     <property name="kundera.nodes" value="a.b.com" /> 
     <property name="kundera.port" value="9042"/> 
     <property name="kundera.keyspace" value="KunderaExamples" /> 
     <property name="kundera.dialect" value="cassandra" /> 
     <property name="kundera.client.lookup.class" value="com.impetus.client.cassandra.thrift.ThriftClientFactory" /> 
     <property name="kundera.ddl.auto.prepare" value="create" /> 
    </properties> 
</persistence-unit> 

虽然试图执行下面的语句,

EntityManagerFactory emf = Persistence.createEntityManagerFactory("cassandra_pu");

发生此异常:

异常线程 “main” com.impetus.kundera.configure.schema.SchemaGenerationException:org.apache.thrift.transport.TTransportException:读一负帧大小(-2113929216)!
在com.impetus.client.cassandra.schemamanager.CassandraSchemaManager.create(CassandraSchemaManager.java:264)
在com.impetus.kundera.configure.schema.api.AbstractSchemaManager.handleOperations(AbstractSchemaManager.java:264)
在com.impetus.kundera.configure.schema.api.AbstractSchemaManager.exportSchema(AbstractSchemaManager.java:115)
在com.impetus.client.cassandra.schemamanager.CassandraSchemaManager.exportSchema(CassandraSchemaManager.java:166)
在COM .impetus.kundera.configure.SchemaConfiguration.configure(SchemaConfiguration.java:188)
at com.impetus.kundera.configure.ClientMetadataBuilder.buildClientFactoryMetadata(Cli entMetadataBuilder.java:48)
在com.impetus.kundera.persistence.EntityManagerFactoryImpl.configureClientFactories(EntityManagerFactoryImpl.java:408)
在com.impetus.kundera.persistence.EntityManagerFactoryImpl.configure(EntityManagerFactoryImpl.java:161)
在com.impetus.kundera.persistence.EntityManagerFactoryImpl。(EntityManagerFactoryImpl.java:135)
在com.impetus.kundera.KunderaPersistence.createEntityManagerFactory(KunderaPersistence.java:85)
在javax.persistence.Persistence.createEntityManagerFactory(持久性。 java:79)
at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:54)
在Main.main(Main.java:16)

然后我和昆德拉(2.4)的更老版本的尝试,面临同样的问题。我想我错过了一些基本的东西。

删除了persistence.xml中的自动模式生成选项,并且仍然面临相同的问题(无法创建新的Cassandra连接。org.apache.thrift.transport.TTransportException:读取负的帧大小(-2113929216)! 。)

在服务器上,这是个例外:

java.lang.ArrayIndexOutOfBoundsException:47
在org.apache.cassandra.transport.Message $ Type.fromOpcode(消息。java:106)
at org.apache.cassandra.transport.Frame $ Decoder.decode(Frame.java:168)
at org.jboss.netty.handler.codec.frame.FrameDecoder.callDecode(FrameDecoder.java:425 )

+1

尝试使用[最新版本](http://mvnrepository.com/artifact/com.impetus.kundera.client/kundera-cassandra/3.2)..您可以参考此[文档](https:// github 5分钟) –

+1

您可以添加错误和例外以及您尝试的代码吗? –

+1

如果你用所有这些细节编辑你的问题,对社区会更好。 –

回答

0

节俭客户端需要使用端口9160而不是9042.现在它工作正常。