Я пишу простое приложение в Scala
, которое использует базу данных leveldb через библиотеку leveldbjni
. Мой build.sbt
файл выглядит следующим образом:Scala SBT и библиотека JNI
name := "Whatever"
version := "1.0"
scalaVersion := "2.10.2"
libraryDependencies ++= Seq(
"org.iq80.leveldb" % "leveldb-api" % "0.6",
"org.fusesource.leveldbjni" % "leveldbjni-all" % "1.7"
)
Object
затем отвечает за создание базы данных. К сожалению, если я запустил программу, я вернусь java.lang.UnsatisfiedLinkError
, поднятой библиотекой hawtjni
, которая leveldbjni
использует под капотом.
Ошибка может быть вызвана также легко из консоли: лестницы
scala> import java.io.File
scala> import org.iq80.leveldb._
scala> import org.fusesource.leveldbjni.JniDBFactory._
scala> factory.open(new File("test"), new Options().createIfMissing(true))
java.lang.UnsatisfiedLinkError: org.fusesource.leveldbjni.internal.NativeOptions.init()V
at org.fusesource.leveldbjni.internal.NativeOptions.init(Native Method)
at org.fusesource.leveldbjni.internal.NativeOptions.<clinit>(NativeOptions.java:54)
at org.fusesource.leveldbjni.JniDBFactory$OptionsResourceHolder.init(JniDBFactory.java:98)
at org.fusesource.leveldbjni.JniDBFactory.open(JniDBFactory.java:167)
at .<init>(<console>:15)
...
scala> System getProperty "java.io.tmpdir"
res2: String = /var/folders/1l/wj6yg_wd15sg_gcql001wchm0000gn/T/
Я не могу понять, что происходит, поскольку библиотека становится правильно извлекаются из файла банки, но он не получает загружен для некоторые причины.
$ file /var/folders/1l/wj6yg_wd15sg_gcql001wchm0000gn/T/lib*
/var/folders/1l/wj6yg_wd15sg_gcql001wchm0000gn/T/libleveldbjni-1.7.jnilib: Mach-O universal binary with 2 architectures
/var/folders/1l/wj6yg_wd15sg_gcql001wchm0000gn/T/libleveldbjni-1.7.jnilib (for architecture x86_64): Mach-O 64-bit dynamically linked shared library x86_64
/var/folders/1l/wj6yg_wd15sg_gcql001wchm0000gn/T/libleveldbjni-1.7.jnilib (for architecture i386): Mach-O dynamically linked shared library i386
Я думаю, что проблема, вероятно, связано с загрузчиком классов, что SBT работает, но я не уверен, так как я относительно новым для Скале.
UPDATE
Все еще не нашли то, что или кто является виновником. Во всяком случае, библиотека фактически найдена и загружена правильно, так как я могу выполнить следующие команды:
scalac> import org.fusesource.leveldbjni.internal.NativeDB
scalac> NativeDB.LIBRARY.load()
Ошибка какая-то образом связанно с функцией init()
, что в соответствии с hawtjni
documentation отвечают за установление всех статических полей аннотированных как постоянные поля с постоянным значением. Исключение может еще быть вызвано типизации:
scalac> import org.fusesource.leveldbjni.internal.NativeOptions
scalac> new NativeOptions()
java.lang.UnsatisfiedLinkError: org.fusesource.leveldbjni.internal.NativeOptions.init()V
at org.fusesource.leveldbjni.internal.NativeOptions.init(Native Method)
at org.fusesource.leveldbjni.internal.NativeOptions.<clinit>(NativeOptions.java:54)
at .<init>(<console>:9)
Что такое системное свойство 'java.library.path'? Вы пытались установить это свойство на путь, где находятся извлеченные библиотеки? – Beryllium
Да, уже пробовал это, используя все возможные варианты конфигурации. По-прежнему такая же ошибка – nopper
Какие версии ОС/JDK вы используете? –