gpt4 book ai didi

java - Stardog 数据库创建给出文件未找到异常

转载 作者:行者123 更新时间:2023-12-01 18:50:54 28 4
gpt4 key购买 nike

我正在使用 java 在 stardog 中创建一个新数据库。

当我创建数据库并在本地主机中导入 RDF 文件时,它的工作正常。

但是当我在远程服务器中创建数据库时,我收到同一 RDF 文件的文件未找到异常。

请看一下我的代码

    System.out.println("start updating db");
String myDBName = "myDB" ;

StardogDBMS dbms =
//StardogDBMS.toServer("snarl://localhost:5820/")
StardogDBMS.toServer("snarl://myRemoteServer:5820/")
.credentials("admin", "admin".toCharArray()).login();

File file = new File("src\\main\\webapp\\test.rdf"))

System.out.println("creating " + myDBName +" and loading the rdf file" );

dbms.disk(myDBName).create(file));
dbms.logout();
System.out.println("created " + myDBName +" and loaded the rdf file" );

请帮忙。是否有任何周转,例如将流传递到数据库以导入 RDF 文件。这是我遇到的异常。

start updating db
creating myDB and loading the rdf file
File: xxx\xxxx\test.RDF Message: java.io.FileNotFoundException: xxx\xxxx\test.RDF (No such file or directory)
created myDB and loaded the rdf file

最佳答案

该错误消息表明磁盘数据库的批量加载器找不到指定的文件。使用 SNARL 协议(protocol)时,文件不会从客户端传输到服务器进行批量加载,这可能是错误的根源。

如果服务器和客户端都在同一台计算机上运行,​​则服务器读取时您的相对路径可能不正确,该路径将相对于 STARDOG_HOME,在这种情况下可能不正确。因此,如果它们都在同一台计算机上,请使用绝对路径,它应该可以工作。如果它们位于不同的计算机上,请从具有服务器的计算机上的 CLI 批量加载。

如果您想使用 HTTP,文件将被传输,但由于将文件发送到服务器的网络开销,您将获得较差的批量加载性能。同样,您最好使用服务器在计算机上进行批量加载。

关于java - Stardog 数据库创建给出文件未找到异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15966789/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com