如何解决Wolfram Mathematica KernelLink-在Java8编译的应用程序中,导出功能无法通过JLink起作用
我一直在努力将Java 6上的应用程序升级到内部使用Wolfram JLink的Java 8。
遇到Java JBoss Fatal error: cannot find the required native library named JLinkNativeLibrary中描述的错误并使用'java.library.path'属性解决该错误后,我遇到了一个函数问题: Export 函数({{ 3}})
- 当应用程序的Java6编译版本时,文件创建于 现场(即file.exists()== true)。
- 的Java8编译版本 应用程序,则文件未创建(导致 在应用程序的后期阶段出现java.nio.file.NoSuchFileException 流)
两个应用程序版本都在同一Windows计算机(CI / CD测试服务器,Windows Server 2008 R2 Standard)上,并且都使用相同的Mathematica路径:
- dllPath = c:/ Program Files / Wolfram Research / Mathematica / 11.1 / SystemFiles / Links / JLink / SystemFiles / Libraries / Windows-x86-64 / JLinkNativeLibrary.dll
- 可执行文件= c:/程序文件/ Wolfram Research / Mathematica / 11.1 / SystemFiles /内核/二进制文件/Windows-x86-64/MathKernel.exe
链接初始化如下:
final String kernelCmd = "-linkmode launch -linkname '" + executablePath + "'";
KernelLink kernelLink = MathLinkFactory.createKernelLink(kernelCmd);
kernelLink.evaluate("Needs[" + KernelLink.PACKAGE_CONTEXT + "]");
kernelLink.discardAnswer();
代码如下(其中 expression 是要导出的 Expr 对象, file 是 File 带有.dat目标文件路径的对象):
final String filePath = file.getCanonicalPath().replaceAll("\\\\","/");
final Expr exp = new Expr(new Expr(Expr.SYMBOL,"Export"),new Expr[]{
new Expr(filePath),expression,new Expr("List")
});
kernelLink.newPacket();
kernelLink.evaluate(exp);
handleEvaluationError(kernelLink.getLastError()); //to log any error
kernelLink.discardAnswer();
烦人的部分是,不会引发MathLinkException也不记录错误。
在Java 8应用程序中,通过JLink的 Export 函数是否有特定需求?
更新2020-08-13
查看上周的应用程序日志(持久存在于数据库中),我发现Export函数的使用在2020-08-07成功,而自2020-08-10起它开始失败。将代码回滚到2020-08-07的状态不会改变上述结果。
我得到一位同事的建议,要检查该计算机上的所有Windows更新。以下更新适用于2020-08-09
- 用于基于x64的系统的Windows Server 2008 R2的2020-07扩展安全更新(ESU)许可准备软件包(KB4575903)-https://reference.wolfram.com/language/ref/Export.html
由于CIS重新部署了Java8编译的应用程序版本,而无论如何都没有碰到java6编译的版本,所以我怀疑此刻问题与环境和权限有关
更新2020-08-14
在https://support.microsoft.com/help/4575903和https://mathematica.stackexchange.com/上进行了一些研究,最终在https://reference.wolfram.com
中找到了关于用于调试的PacketPrinter类的信息在我的应用程序中实现它并获得以下信息:
Packet type was ReturnPacket. Contents follows.
MessagePacket[Export,"nodir"]
Packet type was MessagePacket. Contents follows.
TextPacket["Export::nodir: Directory D:\\some_path\\temp\\mathScripts\\test\\ does not exist."]
MessagePacket[OpenWrite,"noopen"]
Packet type was TextPacket. Contents follows.
MessagePacket[OpenWrite,"noopen"]
Packet type was MessagePacket. Contents follows.
TextPacket["OpenWrite::noopen:
Cannot open D:\\some_path\\temp\\mathScripts\\test\\1597406550292.dat."]
ReturnPacket[$Failed]
Packet type was TextPacket. Contents follows.
ReturnPacket[$Failed]
Packet type was ReturnPacket. Contents follows.
MessagePacket[General,"noopen"]
Packet type was MessagePacket. Contents follows.
TextPacket["General::noopen:
Cannot open D:/some_path/temp/mathScripts/test/1597406550292.dat."]
ReturnPacket[FilePrint["D:/some_path/temp/mathScripts/test/1597406550292.dat"]]
Packet type was TextPacket. Contents follows.
ReturnPacket[FilePrint["D:/some_path/temp/mathScripts/test/1597406550292.dat"]]
Packet type was ReturnPacket. Contents follows.
ReturnPacket[Null]
Packet type was ReturnPacket. Contents follows.
ReturnPacket[Null]
Packet type was ReturnPacket. Contents follows.
ReturnPacket[Null]
看着:
TextPacket["OpenWrite::noopen: Cannot open D:/some_path/temp/mathScripts/test/1597406550292.dat
我当然显示了Mathematica打开和写入文件的问题...
更新2020-08-17
不幸的是,卸载Windows更新“针对基于x64的系统(https://reference.wolfram.com/language/JLink/tutorial/WritingJavaProgramsThatUseTheWolframLanguage.html#21991)的Windows Server 2008 R2的2020-07扩展安全更新(ESU)许可准备软件包”未还原为java8的状态的应用程序的编译版本正在运行...
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。