Skip to content

Ce dépôt fournit une configuration Docker Compose pour mettre en place un environnement d'observabilité avec les composants suivants Grafana, OpenTelemetry, Tempo, Loki, Prometheus

Notifications You must be signed in to change notification settings

SebastienDegodez/observability

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

92 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ObservaBLT avec Grafana

Description

Ce dépôt GitHub fournit une configuration Docker Compose pour mettre en place un environnement d'observabilité avec les composants suivants:

  • Grafana
  • Prometheus
  • Tempo
  • Loki
  • OpenTelemetry

Une application d'exemple .NET Core (WeatherApi) est incluse, et ce README contient un guide étape par étape sur la manière d'améliorer son observabilité en utilisant OpenTelemetry.

architecture

Installation

Pour exécuter l'environnement de surveillance et WeatherApi, assurez-vous d'avoir Docker et Docker Compose installés. Clonez le dépôt et utilisez la commande suivante, pour lancer tous les services nécessaires.

docker compose up -d

Pour arreter les services:

docker compose down

Utilisation

Pour accèder à Grafana: http://localhost:3000 Pour l'accès à Prometheus: http://localhost:9090 Pour l'accès aux metrics exposés par l'OpenTelemetry Collector: http://localhost:8889/metrics

Ajouter de l'Observabilité à une application

Étape 1 : Configurer OpenTelemetry

Ajoutez les packages NuGet OpenTelemetry.Instrumentation.AspNetCore permettant de collecter les données d'ASP.NET Core et Kestrel ainsi que OpenTelemetry.Exporter.OpenTelemetryProtocol permettant d'exporter les données en utilisant le protocole OTLP

dotnet add package OpenTelemetry.Instrumentation.AspNetCore
dotnet add package OpenTelemetry.Exporter.OpenTelemetryProtocol

Dans le projet de l'application, créez une méthode d'extension pour configurer OpenTelemetry.

using Microsoft.AspNetCore.Builder;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using OpenTelemetry.Instrumentation.AspNetCore;

public static class OpenTelemetryExtensions
{
    public static WebApplicationBuilder ConfigureOpenTelemetry(this WebApplicationBuilder builder)
    {
        var useOtlpExporter = !string.IsNullOrWhiteSpace(builder.Configuration["OTEL_EXPORTER_OTLP_ENDPOINT"]);

        return builder;
    }
}

Ajoutez une classe Instrumentation comme celle-ci :

public static class Instrumentation
{
    /// <summary>
    /// The assembly name.
    /// </summary>
    public static readonly AssemblyName AssemblyName = typeof(Instrumentation).Assembly.GetName();

    /// <summary>
    /// The activity source name.
    /// </summary>
    public static readonly string ActivitySourceName = AssemblyName.Name!;

    /// <summary>
    /// The version.
    /// </summary>
    public static readonly Version Version = AssemblyName.Version!;

    /// <summary>
    /// The activity source.
    /// </summary>
    public static readonly ActivitySource ActivitySource = new(ActivitySourceName, Version.ToString());
}

Pour plus d'information Learn Microsoft

Étape 2 : Configuration des Logs

Ajoutez le code nécessaire pour la configuration des logs dans la méthode ConfigureOpenTelemetry. Mettez à jour les options du logger et incluez OpenTelemetry.

builder.Logging.AddOpenTelemetry(o =>
{
    o.IncludeFormattedMessage = true;
    o.IncludeScopes = true;
});

Et ajoutez le code afin de rajouter l'exporter OpenTelemetryProtocol

// ... Code existant
if (useOtlpExporter)
{
    builder.Services.Configure<OpenTelemetryLoggerOptions>(logging => logging.AddOtlpExporter());
}

return builder;

Étape 3 : Configuration des Métriques

Ajoutez l'instrumentation pour ASP.NET Core, le runtime et le client HTTP.

builder.Services.AddOpenTelemetry()
    .ConfigureResource(resource => resource.AddService(serviceName: builder.Environment.ApplicationName))
    .WithMetrics(metrics =>
    {
        metrics.AddAspNetCoreInstrumentation()
               .AddRuntimeInstrumentation()
               .AddHttpClientInstrumentation();
    });

Modifiez le code afin de rajouter l'exporter OpenTelemetryProtocol

// ... Code existant
if (useOtlpExporter)
{
    builder.Services.Configure<OpenTelemetryLoggerOptions>(logging => logging.AddOtlpExporter());
    builder.Services.ConfigureOpenTelemetryMeterProvider(metrics => metrics.AddOtlpExporter());
}
return builder;

Étape 4 : Configuration de la Trace

Configurez les paramètres les traces distribués dans la méthode ConfigureOpenTelemetry.

Et ajoutez l'instrumentation pour ASP.NET Core et le client HTTP.

// ... Code existant
tracing.AddAspNetCoreInstrumentation()
       .AddSource(Instrumentation.ActivitySourceName)
       .AddHttpClientInstrumentation();
// ... Code existant       

Modifiez le code pour rajouter l'exporter OpenTelemetryProtocol

// ... Code existant
if (useOtlpExporter)
{
    // ... Code existant
    builder.Services.ConfigureOpenTelemetryTracerProvider(tracing => tracing.AddOtlpExporter());
}
return builder;

Screenshot

Metrics - ASP.NET Core Grafana Dashboard

Dashboard Grafana

Dashboard Grafana Endpoint

Important

Les dashboards présentés sont inspiré des dashboards dont vous retrouverez le source code ici: https://aka.ms/dotnet/grafana-source.

About

Ce dépôt fournit une configuration Docker Compose pour mettre en place un environnement d'observabilité avec les composants suivants Grafana, OpenTelemetry, Tempo, Loki, Prometheus

Topics

Resources

Stars

Watchers

Forks