6

我正在尝试让 log4net 通过 udp 登录到电锯,但它在 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 回答