Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
Autoinstrumentation enables Application Insights to make telemetry like metrics, requests, and dependencies available in your Application Insights resource. It provides easy access to experiences such as the application dashboard and application map.
The term "autoinstrumentation" is a portmanteau, a linguistic blend where parts of multiple words combine into a new word. "Autoinstrumentation" combines "auto" and "instrumentation." It sees widespread use in software observability and describes the process of adding instrumentation code to applications without manual coding by developers.
The autoinstrumentation process varies by language and platform, but often involves a toggle button in the Azure portal. The following example shows a toggle button for Azure App Service autoinstrumentation.
Tip
We do not provide autoinstrumentation specifics for all languages and platforms in this article. For detailed information, select the corresponding link in the Supported environments, languages, and resource providers table. In many cases, autoinstrumentation is enabled by default.
What are the autoinstrumentation advantages?
- Code changes aren't required.
- Access to source code isn't required.
- Configuration changes aren't required.
- Instrumentation maintenance is eliminated.
Supported environments, languages, and resource providers
The following table shows the current state of autoinstrumentation availability.
Links are provided to more information for each supported scenario.
Note
If your hosting environment or resource provider is not listed in the following table, then autoinstrumentation is not supported. In this case, we recommend manually instrumenting using the Azure Monitor OpenTelemetry Distro. For more information, see Data Collection Basics of Azure Monitor Application Insights.
| Environment/Resource provider | .NET Framework | .NET Core / .NET | Java | Node.js | Python | 
|---|---|---|---|---|---|
| Azure App Service on Windows - Publish as Code | โ ๐ ยน | โ ๐ ยน | โ ๐ ยน | โ ๐ ยน | โ | 
| Azure App Service on Windows - Publish as Container โด | โ ๐ ยฒ | โ ๐ ยฒ | โ ๐ ยฒ | โ ๐ ยฒ | โ | 
| Azure App Service on Linux - Publish as Code | โ | โ ๐ ยน | โ ๐ ยน | โ ๐ ยน | โ ๐ | 
| Azure App Service on Linux - Publish as Container โด | โ | โ ๐ | โ ๐ | โ ๐ | โ | 
| Azure Functions - basic | โ ๐ ยน | โ ๐ ยน | โ ๐ ยน | โ ๐ ยน | โ ๐ ยน | 
| Azure Functions - dependencies | โ | โ | โ ๐ | โ | โ | 
| Azure Spring Apps | โ | โ | โ ๐ | โ | โ | 
| Azure Kubernetes Service (AKS) | โ | โ | โ ๐ ยฒ | โ ๐ ยฒ | โ | 
| Azure VMs Windows | โ ๐ ยฒ ยณ | โ ๐ ยฒ ยณ | โ ๐ | โ | โ | 
| On-premises VMs Windows | โ ๐ ยณ | โ ๐ ยฒ ยณ | โ ๐ | โ | โ | 
| Standalone agent - any environment | โ | โ | โ ๐ | โ | โ | 
Footnotes
- ยน: Application Insights is on by default and enabled automatically.
- ยฒ: This feature is in public preview. See Supplemental Terms of Use for Microsoft Azure Previews.
- ยณ: An agent must be deployed and configured.
- โด: Autoinstrumentation only supports single-container applications. For multi-container applications, manual instrumentation is required using the Azure Monitor OpenTelemetry Distro.
Note
Autoinstrumentation was known as "codeless attach" before October 2021.
Next steps
- To review frequently asked questions (FAQ), see Autoinstrumentation FAQ
- Application Insights overview
- Application Insights overview dashboard
- Application map
