Skip to content

Latest commit

 

History

History
68 lines (39 loc) · 2.5 KB

README.md

File metadata and controls

68 lines (39 loc) · 2.5 KB

ASP.NET Core 6 tracing & monitoring with Opentelemetry and Prometheus

This demo contains client / server applications that use the Opentelemetry .net library for instrumentation and for sending telemetry data to the Opentelemetry collector based on the configuration from otel-collector-config.yaml.

The client periodically makes http calls to the server which create client spans, server spans and metrics that track information like number of http requests and latency.

The applications are also exposing standard dotnet/http Prometheus metrics that are automatically scrapped by Prometheus instance based on the targets specified in prometheus.yml.

This demo implements the following simple flow of microservices (visualization from Zipkin):

drawing

  • The client and server send data directly to the OTel Collector;

  • The OTel Collector then sends the data to the appropriate backend, in this demo Jaeger, Zipkin, and Prometheus;

  • The client and server also send monitoring data directly to Prometheus agent;

This demo uses docker-compose and by default runs against the otel/opentelemetry-collector-contrib-dev:latest image. To run the demo run:

docker-compose up -d

The demo exposes the following backends:

Notes:

  • It may take some time for the application metrics to appear on the Prometheus dashboard;

Running some tests:

  • call the GatewayApi with location value 1 and noOfdays 100 to trigger a call to both Weathersapi and Locationsapi

drawing

  • Prometheus, by default, will monitor standard metrics like a http_request_duration_seconds_count for each application:

drawing

  • Jaeger will display the tracing information starting form the GatewayApi an the duration of the requests:

drawing

  • Opening the details of any of the requests will give details about the response time and and the details of each individual calls to the other applications:

drawing

To clean up any docker container from the demo run docker-compose down.