我在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的位置一样简单。
答案 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所使用的版本,你可以尝试一下,有时它可以工作......