page_type | languages | products | description | urlFragment | ||
---|---|---|---|---|---|---|
sample |
|
|
Adding observability to ASP.NET Core application using OpenTelemetry and Application Insights |
update-this-to-unique-url-stub |
This sample application takes a look at current options to implement observability in a ASP.NET Core. It uses OpenTelemetry and Application Insights SDKs to illustrate how logging, tracing and metrics to monitor an application. It contains a distributed transaction example trace including REST, dependencies and RabbitMQ processing.
File/folder | Description |
---|---|
src |
Sample source code. |
quickstart |
Quick start using docker-compose and pre-built images. |
.gitignore |
Define what to ignore at commit time. |
CHANGELOG.md |
List of changes to the sample. |
CONTRIBUTING.md |
Guidelines for contributing to the sample. |
README.md |
This README file. |
LICENSE |
The license for the sample. |
Sample application can be executed in two ways:
- Using docker-compose. It is a great way to get started.
- Downloading source code and running it locally. Using Visual Studio or another IDE. In this case the .NET Core 3.1 SDK is required. To use Jaeger and Prometheues Docker is recommended.
To run the application using pre-built images and docker-compose following the guideline below:
- Clone this repository
- Open terminal under
quickstart/sample
- Execute
docker-compose up
(-d if you don't wish to see console logs) - View traces in Jaeger
- View metrics by searching for "Enqueued_Item" in Prometheus
- Build dashboards in Grafana (admin/password1)
- Clone this repository
- Open terminal under
quickstart/sample
- Create file
quickstart/sample/.env
with following content:
USE_APPLICATIONINSIGHTS=true
USE_OPENTELEMETRY=false
AI_INSTRUMENTATIONKEY=<ENTER-APPLICATION-INSIGHTS-INSTRUMENTATION-KEY>
- Execute
docker-compose up
(-d if you don't wish to see console logs) - View logs, traces and metrics in Azure Portal Application Insights
Clone or download the sample from this repository, then open the solution found in root folder using your favorite IDE.
Before running ensure the following dependencies are available:
- SQL Server is available at
server=localhost;user id=sa;password=Pass@Word1;
A way to accomplish it is to run as a linux docker container:
docker run --name sqlserver -e "ACCEPT_EULA=Y" -e "SA_PASSWORD=Pass@Word1" -p 1433:1433 -d mcr.microsoft.com/mssql/server:2019-GA-ubuntu-16.04
- When using OpenTelemetry, ensure Jaeger is running locally
docker run -d --name jaeger \
-e COLLECTOR_ZIPKIN_HTTP_PORT=9411 \
-p 5775:5775/udp \
-p 6831:6831/udp \
-p 6832:6832/udp \
-p 5778:5778 \
-p 16686:16686 \
-p 14268:14268 \
-p 9411:9411 \
jaegertracing/all-in-one
-
When using OpenTelemetry, in order to visualize metrics ensure Grafana and Prometheus are running locally. A docker-compose file is ready to run under
quickstart/prometheus-grafana
. Open terminal in the mentioned folder and executedocker-compose up -d
.
To visualize it, open Grafana on your browser at http://localhost:3000 (credentials are admin/password1). Next, add Prometheus as data source (URL is http://prometheus:9090). -
When using Application Insights, ensure the instrumentation key is set (a simpler way to provide settings to all applications is to create file appsettings.Development.json in folder ./shared):
{
"SampleApp": {
"UseApplicationInsights": "true",
"UseOpenTelemetry": "false",
"ApplicationInsightsInstrumentationKey": "<Instrumentation key>"
}
}
The application will only collect data once it starts to receive load. To generate load use the following scripts:
Enqueuing from "WebSiteA" every 2 seconds
watch -n 2 curl --request GET http://localhost:5001/api/enqueue/WebSiteA
while (1) {Invoke-WebRequest -Uri http://localhost:5001/api/enqueue/WebSiteA; sleep 2}
Enqueuing from "WebSiteB" every 10 seconds
watch -n 10 curl --request GET http://localhost:5001/api/enqueue/WebSiteB
while (1) {Invoke-WebRequest -Uri http://localhost:5001/api/enqueue/WebSiteB; sleep 10}
Enqueuing from "WebSiteC" every 30 seconds
watch -n 30 curl --request GET http://localhost:5001/api/enqueue/WebSiteC
while (1) {Invoke-WebRequest -Uri http://localhost:5001/api/enqueue/WebSiteC; sleep 30}
Goal of the sample application is to demonstrate ways you can add the 3 observability pillars to your ASP.NET Core application:
Collects information about events happening in the system, helping the team analyze unexpected application behavior. Searching through the logs of suspect services can provide the necessary hint to identify the problem root cause: service is throwing out of memory exceptions, app configuration does not reflect expected values, calls to external service have incorrect address, calls to external service returns unexpected results, incoming requests have unexpected input, etc.
Logging with Application Insights:
Collects information in order to create an end-to-end view of how transactions are executed in a distributed system. A trace is like a stack trace spanning multiple applications. Once a problem has been recognized, traces are a good starting point in identifying the source in distributed operations: calls from service A to B are taking longer than normal, service payment calls are failing, etc.
Traces with Jaeger:
Traces with Application Insights:
Provide a near real-time indication of how the system is running. Can be leveraged to build alerts, allowing proactive reactance to unexpected values. As opposed to logs and traces, the amount of data collected using metrics remains constant as the system load increases. Application problems are often first detected through abnormal metric values: CPU usage is higher than before, payment error count is spiking, queued item count keeps growing.
This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.
When you submit a pull request, a CLA bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.
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.