jackrabbit-standalone-2.6.0.jar を使用してプログラムでロギングをセットアップしようとしています。このアーカイブには、いくつかの slf4j パッケージ (org.slf4j、org.slf4j.helpers、org.slf4j.impl、org.slf4j.spi) が含まれていますが、私が見る限り、ログ フレームワークはありません。しかし、slf4j-log4j12-1.7.2.jar を追加すると、次のメッセージが表示されます。
SLF4J: [jar:file:/D:/Anwendungen/EclipsePlugins/Jackrabbit/jackrabbit-standalone-2.6.0.jar!/org/slf4j/impl/StaticLoggerBinder.class] でバインディングが見つかりました SLF4J: [jar:file でバインディングが見つかりました] :/D:/Anwendungen/EclipsePlugins/slf4j-1.7.2/slf4j-1.7.2/slf4j-log4j12-1.7.2.jar!/org/slf4j/impl/StaticLoggerBinder.class]
ここでどの種類のインプリメンターが使用されているかを確認する機会はありますか?
ロガーを設定したい。現在、「jackrabit.log_IS_UNDEFINED」というファイルに大量の DEBUG メッセージが書き込まれており、緊急にこれを抑制する必要があります。ロガーのセットアップを提案するヒントがインターネットにいくつかありますが、何をする必要があるのか 正確にはわかりません。クラス「DOMConfigurator」および「PropertyConfigurator」はパッケージ内では使用できませんが、たとえば「slf4j-log4j12-1.7.2.jar」を追加すると、上記のメッセージが表示されます。そのため、プログラム内でロガーを初期化できません。構成 XML をクラスパスに追加するとのことでした。私はこれを試しました(Eclipseで、XMLを含むフォルダーをBuildPathに追加し、XMLファイルからjarファイルを作成し、このjarファイルをBuildPathに追加しました)が、違いはありませんでした。
http://logging.apache.org/log4j/1.2/manual.htmlの「デフォルトの初期化手順」の説明を読みましたが、まったく理解できなかったと言わざるを得ません。意味: 2. リソース文字列変数を log4j.configuration システム プロパティの値に設定します。デフォルトの初期化ファイルを指定するには、log4j.configuration システム プロパティを使用することをお勧めします。システム プロパティ log4j.configuration が定義されていない場合は、文字列変数 resource をデフォルト値の「log4j.properties」に設定します。resource-string 変数はどこで指定する必要がありますか?
私のlog4j.xmlファイル:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<appender name="Console" class="org.apache.log4j.ConsoleAppender">
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %-5p [%c{1}] %m %n" />
</layout>
</appender>
<root>
<priority value="info" />
<appender-ref ref="Console" />
</root>
</log4j:configuration>
ロガーをプログラムで構成するか、デフォルトの初期化にするというアイデアは大歓迎です。
ウルリッヒ