opendaylight 在windows server2012R2下启动运行报错

在开发时opendaylight在windows7下使用,都能正常使用,没有问题,但现在需要将opendaylight放到windows server2012 R2下运行,结果发现运行报错,寻找了很多方式,现在将解决方法分享,希望后来者不再浪费时间。

错误1:java.lang.NoClassDefFoundError: org/fusesource/leveldbjni/JniDBFactory at akka.persistence.journal.leveldb. LeveldbStore$class.leveldbFactory(LeveldbStore.scala:52)

opendaylight 启动karaf 错误信息如下:

Uncaught error from thread [opendaylight-cluster-data-akka.persistence.dispatchers.default-plugin-dispatcher-21]:
org/fusesource/leveldbjni/JniDBFactory, shuttingg down JVM since
‘akka.jvm-exit-on-fatal-error’ is enabled for for ActorSystem[opendaylight-cluster-data]
java.lang.NoClassDefFoundError: org/fusesource/leveldbjni/JniDBFactory
at akka.persistence.journal.leveldb.LeveldbStore c l a s s . l e v e l d b F a c t o r y ( L e v e l d b S t o r e . s c a l a : 52 ) a t a k k a . p e r s i s t e n c e . j o u r n a l . l e v e l d b . L e v e l d b J o u r n a l . l e v e l d b F a c t o r y ( L e v e l d b J o u r n a l . s c a l a : 23 ) a t a k k a . p e r s i s t e n c e . j o u r n a l . l e v e l d b . L e v e l d b S t o r e class.leveldbFactory(LeveldbStore.scala:52) at akka.persistence.journal.leveldb.LeveldbJournal.leveldbFactory(LeveldbJournal.scala:23) at akka.persistence.journal.leveldb.LeveldbStore class.leveldbFactory(LeveldbStore.scala:52)atakka.persistence.journal.leveldb.LeveldbJournal.leveldbFactory(LeveldbJournal.scala:23)atakka.persistence.journal.leveldb.LeveldbStoreclass.preStart(LeveldbStore.scala:178)
at akka.persistence.journal.leveldb.LeveldbJournal.preStart(LeveldbJournal.scala:23)
at akka.actor.Actor$class.aroundPreStart(Actor.scala:510)
at akka.persistence.journal.leveldb.LeveldbJournal.aroundPreStart(LeveldbJournal.scala:23)
at akka.actor.ActorCell.create(ActorCell.scala:590)
at akka.actor.ActorCell.invokeAll 1 ( A c t o r C e l l . s c a l a : 461 ) a t a k k a . a c t o r . A c t o r C e l l . s y s t e m I n v o k e ( A c t o r C e l l . s c a l a : 483 ) a t a k k a . d i s p a t c h . M a i l b o x . p r o c e s s A l l S y s t e m M e s s a g e s ( M a i l b o x . s c a l a : 282 ) a t a k k a . d i s p a t c h . M a i l b o x . r u n ( M a i l b o x . s c a l a : 223 ) a t j a v a . u t i l . c o n c u r r e n t . T h r e a d P o o l E x e c u t o r . r u n W o r k e r ( T h r e a d P o o l E x e c u t o r . j a v a : 1142 ) a t j a v a . u t i l . c o n c u r r e n t . T h r e a d P o o l E x e c u t o r 1(ActorCell.scala:461) at akka.actor.ActorCell.systemInvoke(ActorCell.scala:483) at akka.dispatch.Mailbox.processAllSystemMessages(Mailbox.scala:282) at akka.dispatch.Mailbox.run(Mailbox.scala:223) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) at java.util.concurrent.ThreadPoolExecutor 1(ActorCell.scala:461)atakka.actor.ActorCell.systemInvoke(ActorCell.scala:483)atakka.dispatch.Mailbox.processAllSystemMessages(Mailbox.scala:282)atakka.dispatch.Mailbox.run(Mailbox.scala:223)atjava.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)atjava.util.concurrent.ThreadPoolExecutorWorker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)
在这里插入图片描述修改opendaylight目录下 etc/system.properties,在文件中加入一句org.osgi.framework.os.name = Win32,保存后再次启动
在这里插入图片描述

错误2:Could not load library. Reasons: [no leveldbjni64-1.8 in java.library.path, no leveldbjni-1.8 in java.library.path, F:\CI-CD\dc-karaf-0.1.0-SNAPSHOT\data\cache\org.eclipse.osgi\bundles\183\1.cp\META-INF\native\windows64\leveldbjni.dll: Can’t find dependent libraries, F:\CI-CD\dc-karaf-0.1.0-SNAPSHOT\data\tmp\leveldbjni-64-1-93968114411212963.8: Can’t find dependent libraries]

我在将错误1中的配置文件修改后,启动又报错,这次报错信息不一样了
opendaylight 启动karaf ,错误信息如下:

73% [====================================================> ]Uncaught error from thread [opendaylight-
cluster-data-akka.persistence.dispatchers.default-plugin-dispatcher-23]: Could not load library. Reasons: [no leveldbjni
64-1.8 in java.library.path, no leveldbjni-1.8 in java.library.path, F:\CI-CD\dc-karaf-0.1.0-SNAPSHOT\data\cache\org.ecl
ipse.osgi\bundles\183\1.cp\META-INF\native\windows64\leveldbjni.dll: Can’t find dependent libraries, F:\CI-CD\dc-karaf-
0.1.0-SNAPSHOT\data\tmp\leveldbjni-64-1-93968114411212963.8: Can’t find dependent libraries], shutting down JVM since ‘a
kka.jvm-exit-on-fatal-error’ is enabled for for ActorSystem[opendaylight-cluster-data]
java.lang.UnsatisfiedLinkError: Could not load library. Reasons: [no leveldbjni64-1.8 in java.library.path, no leveldbjn
i-1.8 in java.library.path, F:\CI-CD\dc-karaf-0.1.0-SNAPSHOT\data\cache\org.eclipse.osgi\bundles\183\1.cp\META-INF\nati
ve\windows64\leveldbjni.dll: Can’t find dependent libraries, F:\CI-CD\dc-karaf-0.1.0-SNAPSHOT\data\tmp\leveldbjni-64-1-9
3968114411212963.8: Can’t find dependent libraries]
at org.fusesource.hawtjni.runtime.Library.doLoad(Library.java:187)
at org.fusesource.hawtjni.runtime.Library.load(Library.java:143)
at org.fusesource.leveldbjni.JniDBFactory.(JniDBFactory.java:48)
at akka.persistence.journal.leveldb.LeveldbStore c l a s s . l e v e l d b F a c t o r y ( L e v e l d b S t o r e . s c a l a : 52 ) a t a k k a . p e r s i s t e n c e . j o u r n a l . l e v e l d b . L e v e l d b J o u r n a l . l e v e l d b F a c t o r y ( L e v e l d b J o u r n a l . s c a l a : 23 ) a t a k k a . p e r s i s t e n c e . j o u r n a l . l e v e l d b . L e v e l d b S t o r e class.leveldbFactory(LeveldbStore.scala:52) at akka.persistence.journal.leveldb.LeveldbJournal.leveldbFactory(LeveldbJournal.scala:23) at akka.persistence.journal.leveldb.LeveldbStore class.leveldbFactory(LeveldbStore.scala:52)atakka.persistence.journal.leveldb.LeveldbJournal.leveldbFactory(LeveldbJournal.scala:23)atakka.persistence.journal.leveldb.LeveldbStoreclass.preStart(LeveldbStore.scala:178)
at akka.persistence.journal.leveldb.LeveldbJournal.preStart(LeveldbJournal.scala:23)
at akka.actor.Actor$class.aroundPreStart(Actor.scala:510)
at akka.persistence.journal.leveldb.LeveldbJournal.aroundPreStart(LeveldbJournal.scala:23)
at akka.actor.ActorCell.create(ActorCell.scala:590)
at akka.actor.ActorCell.invokeAll 1 ( A c t o r C e l l . s c a l a : 461 ) a t a k k a . a c t o r . A c t o r C e l l . s y s t e m I n v o k e ( A c t o r C e l l . s c a l a : 483 ) a t a k k a . d i s p a t c h . M a i l b o x . p r o c e s s A l l S y s t e m M e s s a g e s ( M a i l b o x . s c a l a : 282 ) a t a k k a . d i s p a t c h . M a i l b o x . r u n ( M a i l b o x . s c a l a : 223 ) a t j a v a . u t i l . c o n c u r r e n t . T h r e a d P o o l E x e c u t o r . r u n W o r k e r ( T h r e a d P o o l E x e c u t o r . j a v a : 1142 ) a t j a v a . u t i l . c o n c u r r e n t . T h r e a d P o o l E x e c u t o r 1(ActorCell.scala:461) at akka.actor.ActorCell.systemInvoke(ActorCell.scala:483) at akka.dispatch.Mailbox.processAllSystemMessages(Mailbox.scala:282) at akka.dispatch.Mailbox.run(Mailbox.scala:223) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) at java.util.concurrent.ThreadPoolExecutor 1(ActorCell.scala:461)atakka.actor.ActorCell.systemInvoke(ActorCell.scala:483)atakka.dispatch.Mailbox.processAllSystemMessages(Mailbox.scala:282)atakka.dispatch.Mailbox.run(Mailbox.scala:223)atjava.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)atjava.util.concurrent.ThreadPoolExecutorWorker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)
在这里插入图片描述出现这个错误是找不到依赖,是因为在运行时用到了dll外部文件,而系统中没有可以解析运行这文件的环境。想要了解详细信息的可以看system\org\fusesource\leveldbjni\leveldbjni-all目录下的jar包详细信息,入口是JniDBFactory 类的open()方法,在static中 NativeDB.LIBRARY.load();进行了加载dll
在这里插入图片描述
解决办法,在windows server2012中安装Mircrosoft Visual C++软件,这个版本不同也会运行不起,我试了很多个版本,最后如下2010版本下,karaf运行成功。我的opendaylight版本是Carbon-SR4。因为这个版本不好找,这里提供百度网盘下载地址
链接:https://pan.baidu.com/s/15A-9yjB7uzb0kuhsCwqY_g
提取码:s52c
在这里插入图片描述
安装成功后,再次启动karaf,成功
在这里插入图片描述两个错误是独立的,之前另一台机器启动只报了错误2,按照方法解决后成功启动,对应错误修改对应配置就可以了,不用两个都修改

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值