2

Tomcat を使用してデプロイされた Java Web サービスがあります。log4j および NTEventLog dll を使用して、Java からイベント ビューアに書き込もうとしています。システムパスにある C:\Program Files\Java\jdk1.7.0_10\bin に「NTEventLogAppender.dll」を追加し、regsvr32 コマンドを使用して登録しました。

次の例外があります。

5263 [http-8080-2] ERROR org.apache.axis2.transport.http.AxisServlet  - org.apache.log4j.nt.NTEventLogAppender.registerEventSource(Ljava/lang/String;Ljava/lang/String;)I
java.lang.UnsatisfiedLinkError: org.apache.log4j.nt.NTEventLogAppender.registerEventSource(Ljava/lang/String;Ljava/lang/String;)I
    at org.apache.log4j.nt.NTEventLogAppender.registerEventSource(Native Method)
    at org.apache.log4j.nt.NTEventLogAppender.<init>(NTEventLogAppender.java:79)
    at org.apache.log4j.nt.NTEventLogAppender.<init>(NTEventLogAppender.java:49)
    at packagecct1.Procurements.<init>(Procurements.java:101)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
    at java.lang.reflect.Constructor.newInstance(Unknown Source)
    at java.lang.Class.newInstance0(Unknown Source)
    at java.lang.Class.newInstance(Unknown Source)
    at org.apache.axis2.util.Utils$8.run(Utils.java:768)
    at org.apache.axis2.java.security.AccessController.doPrivileged(AccessController.java:132)
    at org.apache.axis2.util.Utils.createServiceObject(Utils.java:765)
    at org.apache.axis2.receivers.AbstractMessageReceiver.makeNewServiceObject(AbstractMessageReceiver.java:245)
    at org.apache.axis2.receivers.AbstractMessageReceiver.getTheImplementationObject(AbstractMessageReceiver.java:282)
    at org.apache.axis2.rpc.receivers.RPCMessageReceiver.invokeBusinessLogic(RPCMessageReceiver.java:78)
    at org.apache.axis2.receivers.AbstractInOutMessageReceiver.invokeBusinessLogic(AbstractInOutMessageReceiver.java:40)
    at org.apache.axis2.receivers.AbstractMessageReceiver.receive(AbstractMessageReceiver.java:114)
    at org.apache.axis2.engine.AxisEngine.receive(AxisEngine.java:181)
    at org.apache.axis2.transport.http.HTTPTransportUtils.processHTTPPostRequest(HTTPTransportUtils.java:172)
    at org.apache.axis2.transport.http.AxisServlet.doPost(AxisServlet.java:146)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:852)
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588)
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
    at java.lang.Thread.run(Unknown Source)

log4j.プロパティ:

#log4j.rootLogger=DEBUG,CA,NTEventLog 
log4j.rootLogger=DEBUG,CA        

#Console Appender 
log4j.appender.CA=org.apache.log4j.ConsoleAppender 
log4j.appender.CA.layout=org.apache.log4j.PatternLayout 
log4j.appender.CA.layout.ConversionPattern=%-4r [%t] %-5p %c %x - %m%n 

#File Appender 
log4j.appender.FA=org.apache.log4j.FileAppender 
log4j.appender.FA.File=sample.log 
log4j.appender.FA.layout=org.apache.log4j.PatternLayout 
log4j.appender.FA.layout.ConversionPattern=%-4r [%t] %-5p %c %x - %m%n

#Event Log Appender
log4j.appender.NTEventLog=org.apache.log4j.nt.NTEventLogAppender
log4j.appender.NTEventLog.layout=org.apache.log4j.PatternLayout
log4j.appender.NTEventLog.layout.ConversionPattern=%m%n
log4j.appender.NTEventLog.source=ESBWebServices


# Set the logger level of File Appender to WARN 
log4j.appender.FA.Threshold = WARN

ジャバコード:

    System.loadLibrary("NTEventLogAppender");

    BasicConfigurator.configure();
    NTEventLogAppender eventLogAppender = new NTEventLogAppender();
    eventLogAppender.setSource("ESBWebServices");

    eventLogAppender.setLayout(new PatternLayout("%m"));
    eventLogAppender.activateOptions();
    logger.addAppender(eventLogAppender);

    logger.info("Hello World!");

IDEとしてEclipseを使用していることに注意してください。

4

2 に答える 2

3

Apache Log4J v1.2.17 には、ビルド前の amd64 互換 DLL (NTEventLogAppender.amd64.dll と呼ばれます。NTEventLogAppender実行時にシステム アーキテクチャ ( System.getProperty("os.arch") を調べます) のみが含まれており、amd64、ia64、または x86 バージョンのNTEventLogAppender..dll という名前のファイルにある必要がある DLL。

Apache は、考えられるすべての DLL を同梱するだけでなく、ディストリビューションの src/ntdll でターゲット アーキテクチャ用の独自の DLL を構築できるように src を提供します。これをビルドするには 2 つの方法があります。1 つは MinGW を使用する方法で、もう 1 つは MS Visual Studio ビルド ツールを使用する方法です。ant msbuild後者を使用して、このディレクトリでコマンドを実行して独自の DLL を構築しました。

それは簡単なプロセスではなく、ビルドに必要な rc、mc、cl、およびリンクの exe だけでなく、さまざまなライブラリやヘッダー ファイルを探し回らなければなりませんでした。最後に、ビルドされた DLL の名前を に変更し、NTEventLogAppender.x86.dllそれを取得するために自分のパスに配置する必要がありました。

とにかく、この DLL ファイルをアップロードする場所が見つからなかったため、ファイルの base64 ハッシュの Gist を作成しました: https://gist.github.com/alpian/5614954。テキストを取得し、多くの無料のオンライン base64 コンバーターのいずれかに通して、適切な名前の DLL ファイルに保存すれば完了です。これは、自分で構築するよりも簡単かもしれませんが、そうではないかもしれません! :)

于 2013-05-20T19:54:13.673 に答える
1

@alpian の返信を拡張すると、実際にlog4j-1.2.17.zip に x86 用にコンパイルされた NTEventLogAppender.dll があり、log4j はライブラリ パス上にある場合、これを正常にロードします。ただし、正しくコンパイルされていないようで、必要な JNI メソッドの C 関数が含まれていないため、OP で言及されている特定の UnsatisfiedLinkError が発生します。

コンパイルする代わりに、DLL が動作しているように見える 1.2.16 にロールバックできます。

于 2016-03-31T15:46:18.050 に答える