解决冲突的依赖关系(Maven)

时间:2016-07-16 17:38:30

标签: java eclipse maven neo4j lucene

我在eclipse中有一个mavenproject,它依赖于包含lucene的jar。

这是我的pom:

      <dependency>
      <groupId>org.dbpedia.spotlight</groupId>
      <artifactId>core</artifactId>
      <version>0.7</version>
      </dependency>
     <dependency>
   <groupId>org.neo4j</groupId>
   <artifactId>neo4j</artifactId>
   <version>3.0.3</version>
  </dependency>
      <dependency>
    <groupId>org.neo4j</groupId>
    <artifactId>neo4j-bolt</artifactId>
    <version>3.0.3</version>
  </dependency>
    <dependency>
   <groupId>org.neo4j</groupId>
   <artifactId>neo4j-kernel</artifactId>
   <version>3.0.3</version>
  </dependency>
  <dependency>
    <groupId>org.neo4j</groupId>
    <artifactId>neo4j-cypher</artifactId>
    <version>3.0.3</version>
</dependency>

问题是,如果包含dbpedia-spotlight-jar,我无法创建/访问我的neo4j-Database。

守则

graphDb = new GraphDatabaseFactory().newEmbeddedDatabaseBuilder( dir )
        .setConfig( GraphDatabaseSettings.read_only, "true" )
        .newGraphDatabase();

给出错误消息

Exception in thread "main" java.lang.RuntimeException: Error starting org.neo4j.kernel.impl.factory.CommunityFacadeFactory, F:\DLs\DB
    at org.neo4j.kernel.impl.factory.GraphDatabaseFacadeFactory.newFacade(GraphDatabaseFacadeFactory.java:144)
    at org.neo4j.kernel.impl.factory.CommunityFacadeFactory.newFacade(CommunityFacadeFactory.java:40)
    at org.neo4j.kernel.impl.factory.GraphDatabaseFacadeFactory.newFacade(GraphDatabaseFacadeFactory.java:108)
    at org.neo4j.graphdb.factory.GraphDatabaseFactory.newDatabase(GraphDatabaseFactory.java:100)
    at org.neo4j.graphdb.factory.GraphDatabaseFactory.lambda$createDatabaseCreator$203(GraphDatabaseFactory.java:89)
    at org.neo4j.graphdb.factory.GraphDatabaseFactory$$Lambda$1/440434003.newDatabase(Unknown Source)
    at org.neo4j.graphdb.factory.GraphDatabaseBuilder.newGraphDatabase(GraphDatabaseBuilder.java:183)
    at neo4j.Neo4j.startServer(Neo4j.java:26)
    at countAnnotator.Main.main(Main.java:35)
Caused by: org.neo4j.kernel.lifecycle.LifecycleException: Component 'org.neo4j.kernel.extension.KernelExtensions@78d4b13a' failed to initialize. Please see attached cause exception.
    at org.neo4j.kernel.lifecycle.LifeSupport$LifecycleInstance.init(LifeSupport.java:416)
    at org.neo4j.kernel.lifecycle.LifeSupport.init(LifeSupport.java:62)
    at org.neo4j.kernel.lifecycle.LifeSupport.start(LifeSupport.java:98)
    at org.neo4j.kernel.impl.factory.GraphDatabaseFacadeFactory.newFacade(GraphDatabaseFacadeFactory.java:140)
    ... 8 more
Caused by: java.lang.VerifyError: Cannot inherit from final class
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClass(Unknown Source)
    at java.security.SecureClassLoader.defineClass(Unknown Source)
    at java.net.URLClassLoader.defineClass(Unknown Source)
    at java.net.URLClassLoader.access$100(Unknown Source)
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at org.neo4j.kernel.api.impl.labelscan.storestrategy.BitmapDocumentFormat.<clinit>(BitmapDocumentFormat.java:40)
    at org.neo4j.kernel.api.impl.labelscan.LuceneLabelScanIndexBuilder.<init>(LuceneLabelScanIndexBuilder.java:34)
    at org.neo4j.kernel.api.impl.labelscan.LuceneLabelScanIndexBuilder.create(LuceneLabelScanIndexBuilder.java:49)
    at org.neo4j.kernel.api.impl.labelscan.LuceneLabelScanStoreExtension.getLuceneIndex(LuceneLabelScanStoreExtension.java:90)
    at org.neo4j.kernel.api.impl.labelscan.LuceneLabelScanStoreExtension.newInstance(LuceneLabelScanStoreExtension.java:79)
    at org.neo4j.kernel.api.impl.labelscan.LuceneLabelScanStoreExtension.newInstance(LuceneLabelScanStoreExtension.java:40)
    at org.neo4j.kernel.extension.KernelExtensions.init(KernelExtensions.java:69)
    at org.neo4j.kernel.lifecycle.LifeSupport$LifecycleInstance.init(LifeSupport.java:406)
    ... 11 more

如果我将dbpedia-spotlight作为依赖项。

如果我没有它作为依赖,它运行得很好。我尝试手动添加jar作为外部存档,并将maven-dependencies置于Buildpath-Order中的“Top”但无效。

我在maven方面相当缺乏经验,所以我想知道如何解决这个问题? 我需要两个罐来运行我的项目(第一步是使用dbpedia-spotlight进行wikification,第二步是使用neo4j计算最短路径 - 只要其他不包括在内,它们都可以工作)。

将neo4j-part放在不同的项目中,原始项目的buildpath中的项目也没有帮助。

提前致谢!

所以我确实找到了解决问题的方法,虽然我真的不明白为什么会这样 - 也许有人可以向我解释。

我仍然拥有dbpedia和neo4j-jars的原始项目。 我还创建了一个不同的空项目,它只有neo4j-dependencies,并将这个项目添加到第一个项目构建路径。

现在我可以从第一个项目中调用wikification和neo4j并且它们可以工作。我的假设是,这导致5.5版本优先于3.6版本,并且dbpedia向上兼容,而neo4j 5.5版本不向下兼容。

这可能也是完全错误的,因为我对构建路径在优先级等方面的工作知之甚少。我偶然通过运气偶然发现了这个解决方案。

无论如何 - 它有效,这对我来说很重要。

edit2:正确的解决方案就像在POM中交换dbpedia-spotlight和noe4j的位置一样简单。

1 个答案:

答案 0 :(得分:2)

关于 https://github.com/dbpedia-spotlight/dbpedia-spotlight/blob/master/pom.xml

版本0.7中的

org.dbpedia.spotlight需要lucene版本3.6.0。

neo4j唯一与lucene有依赖关系的组件,我发现googeling是neo4j-lucene-index。 你没有在你的pom中列出它,但可能是你将它作为传递(间接)依赖。 这适用于lucene 5.5版,请参阅neo4j-lucene-index/3.0.3

所以你现在所做的不适合,你必须找到使用相同版本的lucene的dbpedia版本。

在上述两个链接中,您都可以找到不同版本的dbpedia和neo4j及其依赖项。搜索版本,直到找到一些使用相同的lucene版本。

您也可以运行

mvn dependency:tree

在您的项目上获取有关已使用版本的信息。版本冲突也应该在那里显示。

是否可以使用不同的版本?

简答:否

Maven仅使用依赖项来下载所需的jar并将它们放在项目的类路径中。它总是只为每个依赖项将一个jar文件版本放入类路径中。

如果这个jar包含类,其他一个jar(dbpedia或neo4j)不兼容,你会遇到问题(例外)。

这不是maven特有的问题,它只是java的工作方式。

在运行时neo4j和dbpedia想要使用相同的lucene类实例,因此它们必须以某种方式共享相同版本的lucene。

但是,如果你发现lucene版本接近dbpedia和neo4j所使用的版本,你可以尝试一下,有时它可以工作......