java - 为什么 RDF4J 无法在 Bluemix Cloud Foundry 中工作

标签 java ibm-cloud rdf4j

RDF4J 是一个 apache 开源图形数据库,我经常在我的 PC 上使用。
它带有 2 个 webApp:RDF4J-serverRDF4J-workbench(用户界面)
在我的电脑上,我在同一个 Tomcat 中推送了 2 场 war ,一切正常。
我开始尝试将这些应用程序推送到 Bluemix Cloud(这是一个云类型转换厂)
java-tomcat 样板需要一个 War 以便将其与新容器的 URL 相关联,因此我在 2 个 java 容器中创建 2 个单独的应用程序:
1 个用于 RDF4J 服务器,
1 个用于 RDF4J-WB。
两个应用程序都在运行,我可以访问默认页面。
在 WB 中,“连接到服务器”形式允许您提供要使用的服务器的 URL。
我输入 URL https://rdf4jmyserver.mybluemix.net 。 WB 找到服务器,但在表单上循环,无法打开数据库。

我首先认为分成 2 个容器可能是一个问题,但我做了以下测试:
-在我的机器上的本地 Tomcat 中运行 RD4J 工作台
-连接到云端
rdf4Jmyserver -> 一切都好!
所以 pb 不是在两个不同的地方运行。

我进行了更多调查,下载源代码(感谢开源)并使用越来越多的调试跟踪重新编译。

经过漫长的一天,我发现了 Workbench 代码中的错误,尽管该代码与之前的版本《芝麻:没有人发现它》一样古老。

今天的哲学:
Bluemix 运行良好,但在云中推送应用程序可能会暴露旧的弱点!

我将在下一篇文章中提供补丁。

最佳答案

说明: 当工作台选择的服务器不是默认服务器(应该位于同一根 url 上)时,程序会建立一个新的 cookie 来跟踪新选择。

这里有错误的代码,位于 CookieHandler.java 中:

private void initCookie(final Cookie cookie, final HttpServletRequest req) {
    final String context = req.getContextPath();
     cookie.setPath(null == context ? "/" : context);
    }
}

网址类似于 https://rdf4j-mywb.mybluemix.net
因此,当 cookie 没有上下文时,软件会添加一个/。
但是这段代码是错误的

回到java API,我们可以看到:

public java.lang.String getContextPath()

返回请求 URI 中指示请求上下文的部分。
上下文路径始终在请求 URI 中排在第一位。
路径以“/”字符开头,但不以“/”字符结尾。
对于默认(根)上下文中的 servlet,此方法返回“”。
容器不会解码该字符串。

所以这个古老的隐藏错误可以通过以下方式修复:

// cookie.setPath(null == context ? "/" : context);
cookie.setPath(context.isEmpty()? "/" : context);

现在,Workbench 在 Bluemix 上运行良好!

HTH

PS:由于 rdf4Jserver 也在云容器中运行,因此当容器重置时,磁盘上的数据可能会消失。另一项工作必须完成:使用 Bluemix 中的对象存储服务。 (改天)

关于java - 为什么 RDF4J 无法在 Bluemix Cloud Foundry 中工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42958045/

相关文章:

java - 使用太多的听众是否有潜在的减速?

node.js - 使用nodejs从ibm云函数调用http GET请求

java - 在 IBM bluemix 中使用空间数据

cloud - Cloud Foundry Droplet 和warden 容器有什么区别?

scala - 如何将嵌入的 Blazegraph 内容转储到 RDF 文件中?

java - 如何在 java 中使用 refreshtoken 在 Youtube 中上传视频

java - 错误:找不到或加载正在运行Hadoop的主类

java - Android ViewPager 未显示正确的 fragment

java - rdf4j 过滤器模型由 rdf :id

sesame - 如何使用 RDF4J 控制台以编程方式创建存储库?