Log4net不';t登录到应用程序洞察

Log4net不';t登录到应用程序洞察,log4net,azure-application-insights,Log4net,Azure Application Insights,我将log4net用于我的MVC应用程序。log4net.config文件独立于web.config。我将ApplicationInsights.Log4NetAppender添加到我的UI项目中,并将aiAppender从web.config移动到log4net.config。不知何故,应用程序能够将数据记录到Logs.txt中,但它不能记录到ApplicationInsights 请帮我解决这个问题。 这是我的log4net.config: <log4net> <app

我将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>
在AdaptiveSamplingTelemetryProcessor中,我使用的是自适应采样

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

5.
事件

我可以看到所有依赖项和请求都登录到ApplicationInsights,但无法从log4net中找到任何数据

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

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


这解决了我的问题!我的问题的原因是ApplicationInsights版本比AILog4NetAppender版本旧。一旦我升级了nuget包,问题就解决了。非常感谢。
<?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>