6

Scalaライブラリを介して leveldb データベースを使用する単純なアプリを作成していleveldbjniます。私のbuild.sbtファイルは次のようになります。

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"
)

AnObjectは、データベースの作成を担当します。残念ながら、プログラムを実行すると、フードの下でエクスプロイトするライブラリjava.lang.UnsatisfiedLinkErrorによって生成された が返されます。hawtjnileveldbjni

このエラーは、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 が使用するクラスローダに関連していると思いますが、私は比較的 scala に慣れていないのでわかりません。

アップデート

何が犯人なのか、誰が犯人なのかはまだわかりません。とにかく、次のコマンドを実行できるため、ライブラリは実際に見つかり、正しくロードされています。

scalac> import org.fusesource.leveldbjni.internal.NativeDB
scalac> NativeDB.LIBRARY.load()

エラーは、ドキュメントinit()によると、定数フィールドとして注釈が付けられたすべての静的フィールドを定数値で設定する責任がある関数が原因です。次のように入力することで、例外を引き続きトリガーできます。hawtjni

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)
4

1 に答える 1

2

このsbt issue pageに記載されているように、これは明らかに既知の問題です。eventsourced のドキュメントに従ってrun-nobootcp、Scala ライブラリをブート クラスパスに追加せずにコードを実行するカスタムコマンドを実装しました。

これで問題は解決するはずです。

于 2013-07-20T14:57:21.603 に答える