私はScala
に、leveldbjni
ライブラリを介してleveldbデータベースを使用する単純なアプリケーションを書いています。私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のコンソールからも簡単にトリガすることができます。
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/
ライブラリが正しくjarファイルから抽出なっているが、それはのためにロードされて取得されていないので、私は何が起こっているか理解できませんいくつかの理由。
$ 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()
エラーが原因hawtjni
documentationに応じて注釈を付けすべての静的フィールドを設定するための責任があるinit()
関数に何とかです定数値の定数フィールドとして指定します。
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
どのOS/JDKバージョンを使用していますか? –