Log4Net 和 Application Insights - 没有数据通过

2023-12-05

我在 C# 控制台应用程序中使用 Log4Net,并希望记录的事件也显示在 Application Insights 中。

我添加了 Application Insights 以及 Application Insights Log4Net Appender。

我已按照此处的说明进行操作:https://jan-v.nl/post/using-application-insights-in-your-log4net-application没有运气。

Log4Net 记录正常。但是,当我转到 Application Insights 仪表板时,我看到以下内容:“应用程序在应用程序见解中没有数据。”

在我的主 cs 文件的开头,我有这样的内容:

var telemetryClient = new TelemetryClient { InstrumentationKey = ConfigurationManager.AppSettings["applicationInsights"] };

最后,有这样的:

telemetryClient.Flush();

在我的 app.config 文件中,我有以下内容:

 <log4net>
    <root>
      <level value="INFO" />
      <appender-ref ref="FileAppender" />
      <appender-ref ref="aiAppender" />
    </root>
    <appender name="FileAppender" type="log4net.Appender.FileAppender">
      <file value="C:\logs\logfile.txt" />
      <appendToFile value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] – %message%newline" />
      </layout>
    </appender>
    <appender name="aiAppender" type="Microsoft.ApplicationInsights.Log4NetAppender.ApplicationInsightsAppender, Microsoft.ApplicationInsights.Log4NetAppender">
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%message%newline" />
      </layout>
    </appender>
  </log4net>

当我运行该应用程序时,我在输出窗口中看到这样的内容:

Application Insights Telemetry (unconfigured): {"name":"Microsoft.ApplicationInsights.Message","time":"2017-07-04T10:26:15.7741453Z","tags":{"ai.internal.sdkVersion":"log4net:2.2.0-220","ai.cloud.roleInstance":"xxx","ai.user.id":"AzureAD\\xxx"},"data":{"baseType":"MessageData","baseData":{"ver":2,"message":"xxx","severityLevel":"Information","properties":{xxx"}}}}

我缺少什么?


自从提出这个问题以来,ApplicationInsights 已经不断发展。由于各种原因,原始的静态 TelemetryConfiguration.Active 现在已过时。那些仍然试图快速获得 log4net 配置的人可以这样做(在他们的 log4net 配置文件中):

<appender name="aiAppender" type="Microsoft.ApplicationInsights.Log4NetAppender.ApplicationInsightsAppender, Microsoft.ApplicationInsights.Log4NetAppender">
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%message%newline" />
  </layout>
  <threshold value="INFO" />
  <InstrumentationKey value="12345678-7946-1234-1234-8b330fbe1234" />
</appender>
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Log4Net 和 Application Insights - 没有数据通过 的相关文章

随机推荐