Log4net不会登录到Application Insights

时间:2018-07-27 00:57:43

标签: log4net azure-application-insights

我正在将log4net用于我的MVC应用程序。 log4net.config文件独立于web.config。我将ApplicationInsights.Log4NetAppender添加到我的UI项目中,并将aiAppender从web.config移到了log4net.config。应用程序可以通过某种方式将数据记录到Logs.txt中,但不能记录到ApplicationInsights。

请帮助我解决此问题。 这是我的log4net.config:

<log4net>
  <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender" >
    <file value="App_Data/Logs/Logs.txt" />
    <encoding value="utf-8" />
    <appendToFile value="true" />
    <rollingStyle value="Size" />
    <maxSizeRollBackups value="10" />
    <maximumFileSize value="10000KB" />
    <staticLogFileName value="true" />
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%-5level %date [%-5.5thread] %-40.40logger - %message%newline" />
    </layout>
  </appender>
  <appender name="aiAppender" type="Microsoft.ApplicationInsights.Log4NetAppender.ApplicationInsightsAppender, Microsoft.ApplicationInsights.Log4NetAppender">
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%-5level %date [%-5.5thread] %-40.40logger - %message%newline" />
    </layout>
  </appender>
  <root>
    <level value="DEBUG" />
    <appender-ref ref="RollingFileAppender" />
    <appender-ref ref="aiAppender" />
  </root>
</log4net>

有关应用程序见解的InstrucmentationKey正在读取应用程序设置。

TelemetryConfiguration.Active.InstrumentationKey = WebConfigurationManager.AppSettings["InstrumentationKey"];

在AdaptiveSamplingTelemetryProcessor中,我正在使用自适应采样。

<Add Type="Microsoft.ApplicationInsights.WindowsServer.TelemetryChannel.AdaptiveSamplingTelemetryProcessor, Microsoft.AI.ServerTelemetryChannel">
  <MaxTelemetryItemsPerSecond>5</MaxTelemetryItemsPerSecond>
  <ExcludedTypes>Event</ExcludedTypes>
</Add>

我可以看到所有依赖关系和请求都已登录到ApplicationInsights上,但是找不到来自log4net的任何数据。

1 个答案:

答案 0 :(得分:1)

如果问题出在log4net,则最好启用log4net内部调试:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<appSettings>
    <add key="log4net.Internal.Debug" value="true"/>
</appSettings>
</configuration>

并将其写入文件:

<configuration>
...

<system.diagnostics>
    <trace autoflush="true">
        <listeners>
            <add 
                name="textWriterTraceListener" 
                type="System.Diagnostics.TextWriterTraceListener" 
                initializeData="C:\tmp\log4net.txt" />
        </listeners>
    </trace>
</system.diagnostics>

...
</configuration>

如果有任何异常,您将在日志文件中找到它。也可能是AI记录器使用了缓冲,或者当应用程序退出时,应用程序见解正在缓冲并且没有刷新。

more on Log4net Troubleshooting

flush application insights when your ASP.NET Core application exits