自从添加 IntelliTrace 以来,我注意到在 Azure IaaS VM 上运行时寻找 Microsoft.WindowsAzure.ServiceRunTime.dll 的应用程序洞察的许多例外。
//边注
值得注意的是,这些异常似乎没有在应用程序洞察门户中报告,除了有时我注意到某些图表中有大量异常但无法找到异常详细信息(直到使用 IntelliTrace)......但这可能是红色鲱鱼,也许他们正在被TopShelf 吞噬。
//结束旁注
由于研究我知道这个 dll 实际上在 Azure SDK 中,而不是 nuget 包。
不想为我的服务添加额外的先决条件,我倾向于添加扩展程序集引用并复制到本地。
版本不同,寻找 2.5.0.0 所以还添加了绑定重定向到 2.7.0.0
但是这样做,现在会导致
- 抛出异常异常:Microsoft.WindowsAzure.ServiceRuntime.dll 中的“System.IO.FileNotFoundException”(“无法加载文件或程序集“msshrtmi,版本=2.7.0.0,Culture=neutral,PublicKeyToken=31bf3856ad364e35”或其依赖项之一。系统找不到指定的文件。") System.IO.FileNotFoundException
我担心每次我修复某些东西时,我都需要修复其他东西,然后是其他东西......
这让我回到了我原来的查询...... 实际的问题...... :-)
我没有发现任何表明 Application Insights 甚至需要安装 Azure SDK 的东西。这让我想知道这些异常是否实际上是 Application Insights 只是询问是否安装了 Azure SDK 的第一次机会异常?
作为参考,应用程序洞察设置:
我的 Application Insights nuget 包是:
<package id="Microsoft.ApplicationInsights" version="2.5.0" targetFramework="net462" />
<package id="Microsoft.ApplicationInsights.Agent.Intercept" version="2.4.0" targetFramework="net462" />
<package id="Microsoft.ApplicationInsights.DependencyCollector" version="2.5.0" targetFramework="net462" />
<package id="Microsoft.ApplicationInsights.PerfCounterCollector" version="2.5.0" targetFramework="net462" />
<package id="Microsoft.ApplicationInsights.WindowsServer" version="2.5.0" targetFramework="net462" />
<package id="Microsoft.ApplicationInsights.WindowsServer.TelemetryChannel" version="2.5.0" targetFramework="net462" />
我的配置包括这些 TelemetryInitializers:
<TelemetryInitializers>
<Add Type="Microsoft.ApplicationInsights.DependencyCollector.HttpDependenciesParsingTelemetryInitializer, Microsoft.AI.DependencyCollector"/>
<Add Type="Microsoft.ApplicationInsights.WindowsServer.AzureRoleEnvironmentTelemetryInitializer, Microsoft.AI.WindowsServer"/>
<Add Type="Microsoft.ApplicationInsights.WindowsServer.AzureWebAppRoleEnvironmentTelemetryInitializer, Microsoft.AI.WindowsServer"/>
<Add Type="Microsoft.ApplicationInsights.WindowsServer.BuildInfoConfigComponentVersionTelemetryInitializer, Microsoft.AI.WindowsServer"/>
</TelemetryInitializers>
这些遥测模块:
<TelemetryModules>
<Add Type="Microsoft.ApplicationInsights.DependencyCollector.DependencyTrackingTelemetryModule, Microsoft.AI.DependencyCollector">
<ExcludeComponentCorrelationHttpHeadersOnDomains>
<Add>core.windows.net</Add>
<Add>core.chinacloudapi.cn</Add>
<Add>core.cloudapi.de</Add>
<Add>core.usgovcloudapi.net</Add>
<Add>localhost</Add>
<Add>127.0.0.1</Add>
</ExcludeComponentCorrelationHttpHeadersOnDomains>
<IncludeDiagnosticSourceActivities>
<Add>Microsoft.Azure.EventHubs</Add>
<Add>Microsoft.Azure.ServiceBus</Add>
</IncludeDiagnosticSourceActivities>
</Add>
<Add Type="Microsoft.ApplicationInsights.Extensibility.PerfCounterCollector.PerformanceCollectorModule, Microsoft.AI.PerfCounterCollector">
</Add>
<Add Type="Microsoft.ApplicationInsights.Extensibility.PerfCounterCollector.QuickPulse.QuickPulseTelemetryModule, Microsoft.AI.PerfCounterCollector"/>
<Add Type="Microsoft.ApplicationInsights.WindowsServer.DeveloperModeWithDebuggerAttachedTelemetryModule, Microsoft.AI.WindowsServer"/>
<Add Type="Microsoft.ApplicationInsights.WindowsServer.UnhandledExceptionTelemetryModule, Microsoft.AI.WindowsServer"/>
<Add Type="Microsoft.ApplicationInsights.WindowsServer.UnobservedExceptionTelemetryModule, Microsoft.AI.WindowsServer">
</Add>
</TelemetryModules>
应用程序见解是由其他人设置的,我想知道其中一个扩展是否引起了麻烦,它是针对 Windows 服务的。