6

udp 経由でチェーンソーにログを記録するように log4net を取得しようとしていますが、Windows 7 では機能しません。私の構成ファイルは次のとおりです。

  <log4net debug="true">
<appender name="trace" type="log4net.Appender.TraceAppender, log4net">
  <layout type="log4net.Layout.PatternLayout,log4net">
    <param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" />
  </layout>
</appender>
<appender name="UdpAppender" type="log4net.Appender.UdpAppender">
    <remoteAddress value="127.0.0.1" />
    <remotePort value="8085" />
    <layout type="log4net.Layout.XmlLayoutSchemaLog4j">
      <locationInfo value="true" />
    </layout>
</appender>
<root>
  <level value="TRACE" />
  <appender-ref ref="trace" />
  <appender-ref ref="UdpAppender" />
</root>

私のチェーンソー設定ファイルは次のようになります。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"> 
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="true">    
    <plugin name="UDPReceiver" class="org.apache.log4j.net.UDPReceiver">
        <param name="Port" value="8085" />
    </plugin>    
</log4j:configuration>

これはすべて、http: //logging.apache.org/log4net/release/howto/chainsaw.htmlにあるドキュメントに従っています。

それでも、ログは表示されません。

4

1 に答える 1

5

理解した。log4net には ipv6 と Windows 7 で問題があるようです。これらの問題を回避するには、ホスト ファイルに次のようなエントリを追加する必要があります。

    127.0.0.2       localhosttwo

次に、UpdAppender はその DNS エントリを次のように参照する必要があります。

 <remoteAddress value="localhosttwo" />

127.0.0.2 はローカル マシンの ipv6 アドレスであり、明示的な dns エントリが必要です。そうしないと、構成ファイルで数値アドレスを使用しようとすると、log4net がエラーをスローします。

ホストファイルを変更した後は、必ず dns をフラッシュしてください

于 2012-01-03T18:43:54.063 に答える