Jena TDB java.lang.ExceptionInInitializerError

时间:2016-04-20 21:49:29

标签: java maven-3 jena apache-jena tdb

我正在使用Jena TDB加载RDF数据集并对其进行SPARQL查询。我正在使用以下maven依赖:

<dependency>
    <groupId>org.apache.jena</groupId>
    <artifactId>apache-jena-libs</artifactId>
    <type>pom</type>
    <version>3.0.1</version>
</dependency>

这是我正在尝试创建TDB数据集的java代码:

public void loadDirectory(String outputFile){      
    Dataset dataset = TDBFactory.createDataset(directoryPath);      
    Model tdb = dataset.getDefaultModel();      
    FileManager.get().readModel(tdb, outputFile);      
    tdb.close();      
    dataset.close();      
    LOG.info("RDF dataset loaded to memory");      
}      

它在函数的第一行失败:TDBFactory.createDataset(directoryPath),并显示以下错误消息:

Exception in thread "main" java.lang.ExceptionInInitializerError
    at org.sdw.model.JenaModel.loadDirectory(JenaModel.java:69)
    at org.sdw.Main.main(Main.java:75)
Caused by: java.lang.NullPointerException
    at org.apache.jena.tdb.sys.EnvTDB.processGlobalSystemProperties(EnvTDB.java:33)
    at org.apache.jena.tdb.TDB.init(TDB.java:250)
    at org.apache.jena.tdb.sys.InitTDB.start(InitTDB.java:29)
    at org.apache.jena.system.JenaSystem.lambda$init$40(JenaSystem.java:114)
    at java.util.ArrayList.forEach(ArrayList.java:1249)
    at org.apache.jena.system.JenaSystem.forEach(JenaSystem.java:179)
    at org.apache.jena.system.JenaSystem.forEach(JenaSystem.java:156)
    at org.apache.jena.system.JenaSystem.init(JenaSystem.java:111)
    at org.apache.jena.tdb.TDBFactory.<clinit>(TDBFactory.java:40)

3 个答案:

答案 0 :(得分:6)

POM使用阴影插件。它需要使用ServicesResourceTransformer转换器管理服务文件(META_INF / services /)。

将以下转换内容添加到您的POM文件中:

<transformer implementation="org.apache.maven.plugins.shade.resource.ServicesResourceTransformer" />

例如,请参见<transformers>https://github.com/apache/jena/blob/master/jena-fuseki2/jena-fuseki-server/pom.xml

答案 1 :(得分:1)

我遇到了同样的问题,发现接受的答案通常是正确但不完整的(至少我花了很长时间才弄清楚如何正确应用答案的提示)。这是它的工作原理。

1)您必须将maven-shade插件添加到pom.xml中,如图所示。在:https://github.com/apache/jena/blob/master/jena-fuseki2/jena-fuseki-server/pom.xml

2)更改插件配置中主类的链接。主要课程通过以下方式提供:

<transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
          <mainClass>org.apache.jena.fuseki.cmd.FusekiCmd</mainClass>
</transformer>

您必须在mainClass标记中添加主要类。现在使用maven build命令构建项目时,您将获得一个名为your-project-name-VERSION.jar的jar,它是您想要的可运行jar。如果您以前使用过“带依赖关系的jar”,那么请确保运行新的(不再包含名称中的“with dependencies”),否则您将遇到同样的问题。

答案 2 :(得分:1)

接受的答案实际上是缺少解决方案。 所以这里是:

链接文件为:https://github.com/apache/jena/blob/master/jena-fuseki2/jena-fuseki-server/pom.xml

当然,您应该从中得到什么?

这是您应该添加到pom中的完整片段:

<build>     
<plugins>     
  <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-shade-plugin</artifactId>
    <version>2.1</version>

    <executions>    
      <execution>
        <phase>package</phase>
        <goals>
          <goal>shade</goal>
        </goals>
        <configuration>
          <transformers>
            <transformer implementation="org.apache.maven.plugins.shade.resource.ServicesResourceTransformer" />
            <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
              <mainClass>com.example.MainClass</mainClass>
            </transformer>
          </transformers>
        </configuration>
      </execution>
    </executions>
  </plugin>
</plugins>
</build>

请记住将com.example.MainClass替换为您的主班