Release notes for Microsoft.ApplicationInsights.SnapshotCollector

This article contains the releases notes for the Microsoft.ApplicationInsights.SnapshotCollector NuGet package for .NET applications, which is used by the Application Insights Snapshot Debugger.

Learn more about the Application Insights Snapshot Debugger for .NET applications.

For bug reports and feedback, open an issue on GitHub at https://github.com/microsoft/ApplicationInsights-SnapshotCollector

Note

On March 31, 2025, support for instrumentation key ingestion will end. Instrumentation key ingestion will continue to work, but we'll no longer provide updates or support for the feature. Transition to connection strings to take advantage of new capabilities.

Release notes

1.4.3

A point release to address user-reported bugs.

Bug fixes

1.4.2

A point release to address a user-reported bug.

Bug fixes

1.4.1

A point release to revert a breaking change introduced in 1.4.0.

Bug fixes

1.4.0

Address multiple improvements and added support for Azure Active Directory (AAD) authentication for Application Insights ingestion.

Changes

  • Snapshot Collector package size reduced by 60%. From 10.34 MB to 4.11 MB.
  • Target netstandard2.0 only in Snapshot Collector.
  • Bump Application Insights SDK dependency to 2.15.0.
  • Add back MinidumpWithThreadInfo when writing dumps.
  • Add CompatibilityVersion to improve synchronization between Snapshot Collector agent and uploader on breaking changes.
  • Change SnapshotUploader LogFile naming algorithm to avoid excessive file I/O in App Service.
  • Add pid, role name, and process start time to uploaded blob metadata.
  • Use System.Diagnostics.Process where possible in Snapshot Collector and Snapshot Uploader.

New features

1.3.7.5

A point release to backport a fix from 1.4.0-pre.

Bug fixes

1.3.7.4

A point release to address a problem discovered in testing Azure App Service's codeless attach scenario.

Changes

  • The netcoreapp3.0 target now depends on Microsoft.ApplicationInsights.AspNetCore >= 2.1.1 (previously >= 2.1.2).

1.3.7.3

A point release to address a couple of high-impact issues.

Bug fixes

  • Fixed PDB discovery in the wwwroot/bin folder, which was broken when we changed the symbol search algorithm in 1.3.6.
  • Fixed noisy ExtractWasCalledMultipleTimesException in telemetry.

1.3.7

Changes

  • The netcoreapp2.0 target of SnapshotCollector depends on Microsoft.ApplicationInsights.AspNetCore >= 2.1.1 (again). This reverts behavior to how it was before 1.3.5. We tried to upgrade it in 1.3.6, but it broke some Azure App Service scenarios.

New features

  • Snapshot Collector reads and parses the ConnectionString from the APPLICATIONINSIGHTS_CONNECTION_STRING environment variable or from the TelemetryConfiguration. Primarily, this is used to set the endpoint for connecting to the Snapshot service. For more information, see the Connection strings documentation.

Bug fixes

  • Switched to using HttpClient for all targets except net45 because WebRequest was failing in some environments due to an incompatible SecurityProtocol (requires TLS 1.2).

1.3.6

Changes

  • SnapshotCollector now depends on Microsoft.ApplicationInsights >= 2.5.1 for all target frameworks. This may be a breaking change if your application depends on an older version of the Microsoft.ApplicationInsights SDK.
  • Remove support for TLS 1.0 and 1.1 in Snapshot Uploader.
  • Period of PDB scans now defaults 24 hours instead of 15 minutes. Configurable via PdbRescanInterval on SnapshotCollectorConfiguration.
  • PDB scan searches top-level folders only, instead of recursive. This may be a breaking change if your symbols are in subfolders of the binary folder.

New features

  • Log rotation in SnapshotUploader to avoid filling the logs folder with old files.
  • Deoptimization support (via ReJIT on attach) for .NET Core 3.0 applications.
  • Add symbols to NuGet package.
  • Set additional metadata when uploading minidumps.
  • Added an Initialized property to SnapshotCollectorTelemetryProcessor. It's a CancellationToken, which will be canceled when the Snapshot Collector is completely initialized and connected to the service endpoint.
  • Snapshots can now be captured for exceptions in dynamically generated methods. For example, the compiled expression trees generated by Entity Framework queries.

Bug fixes

  • AmbiguousMatchException loading Snapshot Collector due to Status Monitor.
  • GetSnapshotCollector extension method now searches all TelemetrySinks.
  • Don't start the Snapshot Uploader on unsupported platforms.
  • Handle InvalidOperationException when deoptimizing dynamic methods (for example, Entity Framework)

1.3.5

  • Add support for Sovereign clouds (Older versions won't work in sovereign clouds)
  • Adding snapshot collector made easier by using AddSnapshotCollector(). More information can be found here.
  • Use FISMA MD5 setting for verifying blob blocks. This avoids the default .NET MD5 crypto algorithm, which is unavailable when the OS is set to FIPS-compliant mode.
  • Ignore .NET Framework frames when deoptimizing function calls. This behavior can be controlled by the DeoptimizeIgnoredModules configuration setting.
  • Add DeoptimizeMethodCount configuration setting that allows deoptimization of more than one function call. More information here

1.3.4

  • Allow structured Instrumentation Keys.
  • Increase SnapshotUploader robustness - continue startup even if old uploader logs can't be moved.
  • Re-enabled reporting additional telemetry when SnapshotUploader.exe exits immediately (was disabled in 1.3.3).
  • Simplify internal telemetry.
  • Experimental feature: Snappoint collection plans: Add "snapshotOnFirstOccurence". More information available here.

1.3.3

  • Fixed bug that was causing SnapshotUploader.exe to stop responding and not upload snapshots for .NET Core apps.

1.3.2

  • Experimental feature: Snappoint collection plans. More information available here.
  • SnapshotUploader.exe will exit when the runtime unloads the AppDomain from which SnapshotCollector is loaded, instead of waiting for the process to exit. This improves the collector reliability when hosted in IIS.
  • Add configuration to allow multiple SnapshotCollector instances that are using the same Instrumentation Key to share the same SnapshotUploader process: ShareUploaderProcess (defaults to true).
  • Report additional telemetry when SnapshotUploader.exe exits immediately.
  • Reduced the number of support files SnapshotUploader.exe needs to write to disk.

1.3.1

  • Remove support for collecting snapshots with the RtlCloneUserProcess API and only support PssCaptureSnapshots API.
  • Increase the default limit on how many snapshot can be captured in 10 minutes from 1 to 3.
  • Allow SnapshotUploader.exe to negotiate TLS 1.1 and 1.2
  • Report additional telemetry when SnapshotUploader logs a warning or an error
  • Stop taking snapshots when the backend service reports the daily quota was reached (50 snapshots per day)
  • Add extra check in SnapshotUploader.exe to not allow two instances to run in the same time.

1.3.0

Changes

  • For applications targeting .NET Framework, Snapshot Collector now depends on Microsoft.ApplicationInsights version 2.3.0 or above. It used to be 2.2.0 or above. We believe this won't be an issue for most applications, but let us know if this change prevents you from using the latest Snapshot Collector.
  • Use exponential back-off delays in the Snapshot Uploader when retrying failed uploads.
  • Use ServerTelemetryChannel (if available) for more reliable reporting of telemetry.
  • Use 'SdkInternalOperationsMonitor' on the initial connection to the Snapshot Debugger service so that it's ignored by dependency tracking.
  • Improve telemetry around initial connection to the Snapshot Debugger service.
  • Report additional telemetry for:
    • Azure App Service version.
    • Azure compute instances.
    • Containers.
    • Azure Function app.

Bug fixes

  • When the problem counter reset interval is set to 24 days, interpret that as 24 hours.
  • Fixed a bug where the Snapshot Uploader would stop processing new snapshots if there was an exception while disposing a snapshot.

1.2.3

  • Fix strong-name signing with Snapshot Uploader binaries.

1.2.2

Changes

  • The files needed for SnapshotUploader(64).exe are now embedded as resources in the main DLL. That means the SnapshotCollectorFiles folder is no longer created, simplifying build and deployment and reducing clutter in Solution Explorer. Take care when upgrading to review the changes in your .csproj file. The Microsoft.ApplicationInsights.SnapshotCollector.targets file is no longer needed.
  • Telemetry is logged to your Application Insights resource even if ProvideAnonymousTelemetry is set to false. This is so we can implement a health check feature in the Azure portal. ProvideAnonymousTelemetry affects only the telemetry sent to Microsoft for product support and improvement.
  • When the TempFolder or ShadowCopyFolder are redirected to environment variables, keep the collector idle until those environment variables are set.
  • For applications that connect to the Internet via a proxy server, Snapshot Collector will now autodetect any proxy settings and pass them on to SnapshotUploader.exe.
  • Lower the priority of the SnapshotUplaoder process (where possible). This priority can be overridden via the IsLowPrioirtySnapshotUploader option.
  • Added a GetSnapshotCollector extension method on TelemetryConfiguration for scenarios where you want to configure the Snapshot Collector programmatically.
  • Set the Application Insights SDK version (instead of the application version) in customer-facing telemetry.
  • Send the first heartbeat event after two minutes.

Bug fixes

  • Fix NullReferenceException when exceptions have null or immutable Data dictionaries.
  • In the uploader, retry PDB matching a few times if we get a sharing violation.
  • Fix duplicate telemetry when more than one thread calls into the telemetry pipeline at startup.

1.2.1

Changes

  • XML Doc comment files are now included in the NuGet package.
  • Added an ExcludeFromSnapshotting extension method on System.Exception for scenarios where you know you have a noisy exception and want to avoid creating snapshots for it.
  • Added an IsEnabledWhenProfiling configuration property, defaults to true. This is a change from previous versions where snapshot creation was temporarily disabled if the Application Insights Profiler was performing a detailed collection. The old behavior can be recovered by setting this property to false.

Bug fixes

  • Sign SnapshotUploader64.exe properly.
  • Protect against double-initialization of the telemetry processor.
  • Prevent double logging of telemetry in apps with multiple pipelines.
  • Fix a bug with the expiration time of a collection plan, which could prevent snapshots after 24 hours.

1.2.0

The biggest change in this version (hence the move to a new minor version number) is a rewrite of the snapshot creation and handling pipeline. In previous versions, this functionality was implemented in native code (ProductionBreakpoints*.dll and SnapshotHolder*.exe). The new implementation is all managed code with P/Invokes. For this first version using the new pipeline, we haven't strayed far from the original behavior. The new implementation allows for better error reporting and sets us up for future improvements.

Other changes in this version

  • MinidumpUploader.exe has been renamed to SnapshotUploader.exe (or SnapshotUploader64.exe).
  • Added timing telemetry to DeOptimize/ReOptimize requests.
  • Added gzip compression for minidump uploads.
  • Fixed a problem where PDBs were locked preventing site upgrade.
  • Log the original folder name (SnapshotCollectorFiles) when shadow-copying.
  • Adjust memory limits for 64-bit processes to prevent site restarts due to OOM.
  • Fix an issue where snapshots were still collected even after disabling.
  • Log heartbeat events to customer's AI resource.
  • Improve snapshot speed by removing "Source" from Problem ID.

1.1.2

Changes

Augmented usage telemetry

  • Detect and report .NET version and OS
  • Detect and report additional Azure Environments (Cloud Service, Service Fabric)
  • Record and report exception metrics (number of 1st chance exceptions and number of TrackException calls) in Heartbeat telemetry.

Bug fixes

  • Correct handling of SqlException where the inner exception (Win32Exception) isn't thrown.
  • Trim trailing spaces on symbol folders, which caused an incorrect parse of command-line arguments to the MinidumpUploader.
  • Prevent infinite retry of failed connections to the Snapshot Debugger agent's endpoint.

1.1.0

Changes

  • Added host memory protection. This feature reduces the impact on the host machine's memory.
  • Improve the Azure portal snapshot viewing experience.