0

Cassandraデータベースに接続し、cassandra astyanax Javaクライアントを介してデータを挿入するためのMavenプロジェクトを作成しました。

maven clean と install は正常にビルドされますが、この Java アプリケーションを実行すると次のエラーが発生します

Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/cassandra/dht/Murmur3Partitioner
    at com.netflix.astyanax.impl.AstyanaxConfigurationImpl.<init>(AstyanaxConfigurationImpl.java:55)
    at ConnectingAstyanax.cassandraConnection(ConnectingAstyanax.java:23)
    at ConnectingAstyanax.main(ConnectingAstyanax.java:66)
Caused by: java.lang.ClassNotFoundException: org.apache.cassandra.dht.Murmur3Partitioner
    at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:423)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:356)

pom.xmlは次のとおりです

 <modelVersion>4.0.0</modelVersion>
  <groupId>CassandraAstyanax</groupId>
  <artifactId>CassandraAstyanax</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <build>
    <sourceDirectory>src</sourceDirectory>
    <plugins>
      <plugin>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>2.3.2</version>
        <configuration>
          <source>1.7</source>
          <target>1.7</target>
        </configuration>
      </plugin>
    </plugins>
  </build>
  <dependencies>
        <dependency>
              <groupId>com.netflix.astyanax</groupId>
              <artifactId>astyanax-thrift</artifactId>
              <version>1.56.31</version>
              </dependency>
              <dependency>
              <groupId>com.netflix.astyanax</groupId>
              <artifactId>astyanax-core</artifactId>
              <version>1.56.31</version>
              </dependency>
              <dependency>
              <groupId>com.netflix.astyanax</groupId>
              <artifactId>astyanax-cassandra</artifactId>
              <version>1.56.31</version>
              </dependency>
              <dependency>
                <groupId>org.apache.cassandra</groupId>
                <artifactId>cassandra-thrift</artifactId>
                <version>1.1.2</version>
            </dependency>
            <dependency>
                <groupId>org.apache.cassandra</groupId>
                <artifactId>cassandra-all</artifactId>
                <version>1.1.2</version>
            </dependency>


  </dependencies>
</project>

エラーを解決するための助けをいただければ幸いです..

4

1 に答える 1

3

Murmur3Partitioner は Cassandra 1.2 で導入されました。1.1 ではなく 1.2 バージョンを取得するには、pom を更新する必要があります。

于 2013-03-21T12:29:35.590 に答える