Enrich the telemetry data for .NET applications running inside containers that are managed by Kubernetes.
Перейти к файлу
Saar Shen c1368b7695
Hosting startup 6.0 (#335)
* Adding missed spot of hosting startup.

* Add dependency between release and debug

* Update CI

* Simplify and parallel ci builds
2023-01-26 17:06:22 -08:00
.github/workflows Hosting startup 6.0 (#335) 2023-01-26 17:06:22 -08:00
build Dev/saars/split service collection (#151) 2018-11-19 11:01:28 -08:00
dev Clean up lifetime of registered services (#309) 2022-09-08 16:08:19 -07:00
docs Support telemetry enhancement without cluster role (#305) 2022-09-02 10:13:09 -07:00
examples Make bootstrap idempotent (#328) 2022-10-25 11:54:53 -07:00
src Hosting startup 6.0 (#335) 2023-01-26 17:06:22 -08:00
tests Bump up unit test sdk to 17.4.0 2022-11-13 10:17:07 -08:00
troubleshooting Dev/saars/compliance docker registry (#263) 2022-05-23 11:23:28 -07:00
.editorconfig Dev/saars/container id fallback (#247) 2022-03-18 14:12:25 -07:00
.gitignore Expose k8s cluster info through IK8sInfoService (#313) 2022-09-12 10:37:52 -07:00
ApplicationInsights.Kubernetes.sln Dev/saars/container id fallback (#247) 2022-03-18 14:12:25 -07:00
LICENSE Update LICENSE 2017-05-05 15:53:56 -07:00
NuGet.config Clean up nuget feeds (#227) 2021-04-01 17:25:48 -07:00
README.md Update README.md 2022-10-11 11:59:36 -07:00
SECURITY.md Microsoft mandatory file (#254) (#256) 2022-05-19 08:42:47 -07:00
solution.code-workspace Dev/saars/improve svc collector (#224) 2021-04-01 16:37:59 -07:00

README.md

Microsoft Application Insights for Kubernetes

Nuget Downloads

Application Insights for Kubernetes enhances telemetries with K8s properties, works for .NET Core/.NET 6 applications in Kubernetes clusters.

Screenshot for Application Insights for Kubernetes enhanced telemetry

⚠️ Microsoft Application Insights for Kubernetes (this library) is an enhancement to the Microsoft Application Insights. You can choose to run Application Insights without this library in a Kubernetes cluster. However, with Microsoft Application Insights for Kubernetes, you will see Kubernetes-related properties like Pod-Name, Deployment ... on all your telemetry entries. Proper values will also be set to make use of the rich features like enabling the Application Map to show the multiple microservices/roles on the same application insights map.

Continuous Integration Status

Rolling Build Nightly Build
Rolling-Build Status Nightly-Build Status

Get Started

This is a quick guide for ASP.NET Core projects.

Prerequisite

⚠️ For RBAC-enabled Kubernetes, make sure permissions are configured.

Instrument an ASP.NET Core application

⚠️ This is for ASP.NET Core application. See instructions for workers in the Walk-through section below.

  1. Add references to Application Insights SDK and Application Insights for Kubernetes:

    dotnet add package Microsoft.ApplicationInsights.AspNetCore
    dotnet add package Microsoft.ApplicationInsights.Kubernetes
    
  2. Enable Application Insights and Application Insights for Kubernetes Enricher in Startup.cs:

    public void ConfigureServices(IServiceCollection services)
    {
        ...
        services.AddApplicationInsightsTelemetry("----Your Application Insights Instrumentation Key ----");
        services.AddApplicationInsightsKubernetesEnricher();
        services.AddMvc();
        ...
    }
    
  3. Build the application in containers, then deploy the container with Kubernetes.

Notes: Those steps are not considered the best practice to set the instrumentation key for application insights. Refer to Enable Application Insights server-side telemetry for various options. Also, consider deploying Kubernetes Secrets to secure it. Refer to Deploy the application in Kubernetes for an example.

Walk-through with example code

Customize Configurations

Customize configurations are supported. There are several ways to customize the settings. For example:

  1. Using code:

    services.AddApplicationInsightsKubernetesEnricher(option=> {
        option.InitializationTimeout = TimeSpan.FromSeconds(15);
    });
    
  2. Using appsettings.json:

    {
        "Logging": {
            // ...
        },
        // Adding the following section to set the timeout to 15 seconds
        "AppInsightsForKubernetes": {
            "InitializationTimeout": "00:00:15"
        }
    }
    
  3. Using environment variables:

    AppInsightsForKubernetes__InitializationTimeout=3.1:12:15.34
    

    All the related configurations have to be put in a section named AppInsightsForKubernetes. The supported keys/values are listed below:

    Key Value/Types Default Value Description
    InitializationTimeout TimeSpan 00:02:00 Maximum time to wait for spinning up the container. Accepted format: [d.]hh:mm:ss[.fffffff].
    ClusterInfoRefreshInterval TimeSpan 00:10:00 For 3.x only. Get or sets how frequent to refresh the Kubernetes cluster properties.
    DisablePerformanceCounters Boolean false Deprecated. Sets to true to avoid adding performance counter telemetry initializer.

Tips: Refer to AppInsightsForKubernetesOptions.cs for the latest customization supported.

The configuration uses the ASP.NET Core conventions. Refer to Configuration in ASP.NET Core for more information.

Verify the cluster configuration (Linux Container only)

Use the troubleshooting image to verify the cluster is properly configured.

Learn more

Next step

Profile your application for performance improvement using Application Insights Profiler for Linux.

Contributing

Report issues

Please file bug, discussion or any other interesting topics in issues on GitHub.

Troubleshooting

Read the FAQ for common issues. When Microsoft.ApplicationInsights.Kubernetes doesn't work properly, you can turn on self-diagnostics to see the traces in Kubernetes' logs. Refer to How to enable self diagnostics for ApplicationInsights.Kubernetes for instructions.

Developing

Please refer the Develop Guide.


This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.