【Nd4j 运行异常解决方案】

Nd4j 运行异常解决方案

使用Nd4j版本

      <dependency>
          <groupId>org.nd4j</groupId>
          <artifactId>nd4j-native</artifactId>
          <version>1.0.0-M1.1</version>
      </dependency>

本地开发环境运行正常,但部署到服务器环境运行异常

java.lang.ExceptionInInitializerError
    at org.nd4j.linalg.cpu.nativecpu.ops.NativeOpExecutioner.<init> (NativeOpExecutioner.java:78)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0 (Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance (NativeConstructorAccessorImpl.java:62)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance (DelegatingConstructorAccessorImpl.java:45)
    at java.lang.reflect.Constructor.newInstance (Constructor.java:423)
    at java.lang.Class.newInstance (Class.java:442)
    at org.nd4j.linalg.factory.Nd4j.initWithBackend (Nd4j.java:5178)
    at org.nd4j.linalg.factory.Nd4j.initContext (Nd4j.java:5093)
    at org.nd4j.linalg.factory.Nd4j.<clinit> (Nd4j.java:270)
    at HelloNd4j.main (HelloNd4j.java:5)
    at org.codehaus.mojo.exec.ExecJavaMojo$1.run (ExecJavaMojo.java:254)
    at java.lang.Thread.run (Thread.java:748)
Caused by: java.lang.RuntimeException: ND4J is probably missing dependencies. For more information, please refer to: https://deeplearning4j.konduit.ai/nd4j/backend
    at org.nd4j.nativeblas.NativeOpsHolder.<init> (NativeOpsHolder.java:116)
    at org.nd4j.nativeblas.NativeOpsHolder.<clinit> (NativeOpsHolder.java:37)
    at org.nd4j.linalg.cpu.nativecpu.ops.NativeOpExecutioner.<init> (NativeOpExecutioner.java:78)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0 (Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance (NativeConstructorAccessorImpl.java:62)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance (DelegatingConstructorAccessorImpl.java:45)
    at java.lang.reflect.Constructor.newInstance (Constructor.java:423)
    at java.lang.Class.newInstance (Class.java:442)
    at org.nd4j.linalg.factory.Nd4j.initWithBackend (Nd4j.java:5178)
    at org.nd4j.linalg.factory.Nd4j.initContext (Nd4j.java:5093)
    at org.nd4j.linalg.factory.Nd4j.<clinit> (Nd4j.java:270)
    at HelloNd4j.main (HelloNd4j.java:5)
    at org.codehaus.mojo.exec.ExecJavaMojo$1.run (ExecJavaMojo.java:254)
    at java.lang.Thread.run (Thread.java:748)
Caused by: java.lang.UnsatisfiedLinkError: no jnind4jcpu in java.library.path
    at java.lang.ClassLoader.loadLibrary (ClassLoader.java:1867)
    at java.lang.Runtime.loadLibrary0 (Runtime.java:870)
    at java.lang.System.loadLibrary (System.java:1122)
    at org.bytedeco.javacpp.Loader.loadLibrary (Loader.java:1718)
    at org.bytedeco.javacpp.Loader.load (Loader.java:1328)
    at org.bytedeco.javacpp.Loader.load (Loader.java:1132)
    at org.nd4j.nativeblas.Nd4jCpu.<clinit> (Nd4jCpu.java:14)
    at java.lang.Class.forName0 (Native Method)
    at java.lang.Class.forName (Class.java:348)
    at org.nd4j.common.config.ND4JClassLoading.loadClassByName (ND4JClassLoading.java:62)
    at org.nd4j.common.config.ND4JClassLoading.loadClassByName (ND4JClassLoading.java:56)
    at org.nd4j.nativeblas.NativeOpsHolder.<init> (NativeOpsHolder.java:88)
    at org.nd4j.nativeblas.NativeOpsHolder.<clinit> (NativeOpsHolder.java:37)
    at org.nd4j.linalg.cpu.nativecpu.ops.NativeOpExecutioner.<init> (NativeOpExecutioner.java:78)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0 (Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance (NativeConstructorAccessorImpl.java:62)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance (DelegatingConstructorAccessorImpl.java:45)
    at java.lang.reflect.Constructor.newInstance (Constructor.java:423)
    at java.lang.Class.newInstance (Class.java:442)
    at org.nd4j.linalg.factory.Nd4j.initWithBackend (Nd4j.java:5178)
    at org.nd4j.linalg.factory.Nd4j.initContext (Nd4j.java:5093)
    at org.nd4j.linalg.factory.Nd4j.<clinit> (Nd4j.java:270)
    at HelloNd4j.main (HelloNd4j.java:5)
    at org.codehaus.mojo.exec.ExecJavaMojo$1.run (ExecJavaMojo.java:254)
    at java.lang.Thread.run (Thread.java:748)
Caused by: java.lang.UnsatisfiedLinkError: /root/.javacpp/cache/nd4j-native-1.0.0-M1.1-linux-x86_64.jar/org/nd4j/nativeblas/linux-x86_64/libjnind4jcpu.so: /lib64/libm.so.6: version `GLIBC_2.23' not found (required by /root/.javacpp/cache/nd4j-native-1.0.0-M1.1-linux-x86_64.jar/org/nd4j/nativeblas/linux-x86_64/libnd4jcpu.so)
    at java.lang.ClassLoader$NativeLibrary.load (Native Method)
    at java.lang.ClassLoader.loadLibrary0 (ClassLoader.java:1941)
    at java.lang.ClassLoader.loadLibrary (ClassLoader.java:1824)
    at java.lang.Runtime.load0 (Runtime.java:809)
    at java.lang.System.load (System.java:1086)
    at org.bytedeco.javacpp.Loader.loadLibrary (Loader.java:1668)
    at org.bytedeco.javacpp.Loader.load (Loader.java:1328)
    at org.bytedeco.javacpp.Loader.load (Loader.java:1132)
    at org.nd4j.nativeblas.Nd4jCpu.<clinit> (Nd4jCpu.java:14)
    at java.lang.Class.forName0 (Native Method)
    at java.lang.Class.forName (Class.java:348)
    at org.nd4j.common.config.ND4JClassLoading.loadClassByName (ND4JClassLoading.java:62)
    at org.nd4j.common.config.ND4JClassLoading.loadClassByName (ND4JClassLoading.java:56)
    at org.nd4j.nativeblas.NativeOpsHolder.<init> (NativeOpsHolder.java:88)
    at org.nd4j.nativeblas.NativeOpsHolder.<clinit> (NativeOpsHolder.java:37)
    at org.nd4j.linalg.cpu.nativecpu.ops.NativeOpExecutioner.<init> (NativeOpExecutioner.java:78)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0 (Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance (NativeConstructorAccessorImpl.java:62)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance (DelegatingConstructorAccessorImpl.java:45)
    at java.lang.reflect.Constructor.newInstance (Constructor.java:423)
    at java.lang.Class.newInstance (Class.java:442)
    at org.nd4j.linalg.factory.Nd4j.initWithBackend (Nd4j.java:5178)
    at org.nd4j.linalg.factory.Nd4j.initContext (Nd4j.java:5093)
    at org.nd4j.linalg.factory.Nd4j.<clinit> (Nd4j.java:270)
    at HelloNd4j.main (HelloNd4j.java:5)
    at org.codehaus.mojo.exec.ExecJavaMojo$1.run (ExecJavaMojo.java:254)
    at java.lang.Thread.run (Thread.java:748)

解决方案:

提示:尝试降低版本

例如:

      <dependency>
          <groupId>org.nd4j</groupId>
          <artifactId>nd4j-native</artifactId>
          <version>1.0.0-beta7</version>
      </dependency>

直到运行成功,免去升级系统lib库的烦恼

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wang_xiaoxin

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值