Řídicí panel .NET.NET Aspire lze nakonfigurovat tak, aby přijímal telemetrická data odesílaná z aplikací prohlížeče. Tato funkce je užitečná pro monitorování výkonu na straně klienta a interakcí uživatelů. Telemetrie prohlížeče vyžaduje další konfiguraci řídicího panelu a že se do aplikací prohlížeče přidá sada JavaScript OTEL SDK.
Tento článek popisuje, jak povolit telemetrii prohlížeče na řídicím panelu .NET.NET Aspire.
Konfigurace řídicího panelu
Telemetrie prohlížeče vyžaduje, aby řídicí panel povolil tyto funkce:
Koncový bod HTTP protokolu OTLP. Tento koncový bod používá řídicí panel k příjmu telemetrie z aplikací prohlížeče.
Sdílení prostředků mezi zdroji (CORS). CORS umožňuje aplikacím v prohlížeči provádět žádosti na řídicí panel.
Konfigurace OTLP
Řídicí panel .NET.NET Aspire přijímá telemetrii prostřednictvím koncových bodů OTLP.
HTTP OTLP koncové body a gRPC OTLP koncové body jsou podporovány řídicím panelem. Aplikace prohlížeče musí k odesílání telemetrických dat na řídicí panel používat protokol HTTP OLTP, protože aplikace prohlížeče nepodporují gRPC.
Pokud chcete nakonfigurovat koncové body gPRC nebo HTTP, zadejte následující proměnné prostředí:
DOTNET_DASHBOARD_OTLP_ENDPOINT_URL: Koncový bod gRPC, ke kterému se řídicí panel připojuje pro svá data.
DOTNET_DASHBOARD_OTLP_HTTP_ENDPOINT_URL: Koncový bod HTTP, ke kterému se řídicí panel připojuje pro svá data.
Konfigurace koncového bodu HTTP OTLP závisí na tom, jestli je řídicí panel spuštěný hostitelem aplikace nebo jestli je spuštěný samostatně.
Konfigurace protokolu HTTP OTLP pomocí hostitele aplikace
Pokud řídicí panel a vaši aplikaci spustí hostitel aplikace, koncové body OTLP řídicího panelu se nakonfigurují v souboru launchSettings.json hostitele aplikace.
Předchozí nastavení spuštění JSON soubor nakonfiguruje všechny profily tak, aby zahrnovaly proměnnou prostředí DOTNET_DASHBOARD_OTLP_HTTP_ENDPOINT_URL.
Konfigurace protokolu HTTP OTLP pomocí samostatného řídicího panelu
Pokud se řídicí panel používá samostatně, bez zbytku .NET.NET Aspire, koncový bod HTTP OTLP je ve výchozím nastavení povolený na portu 18890. Port se ale musí namapovat při spuštění kontejneru řídicího panelu:
Předchozí příkaz spustí kontejner řídicího panelu a mapuje gRPC OTLP na port 4317 a HTTP OTLP na port 4318.
Konfigurace CORS
Ve výchozím nastavení jsou aplikace prohlížeče omezené na volání rozhraní API napříč doménou. To má vliv na odesílání telemetrie na řídicí panel, protože řídicí panel a aplikace prohlížeče jsou vždy na různých doménách. Konfigurace CORS na řídicím panelu .NET.NET Aspire odebere omezení.
Pokud řídicí panel a vaši aplikaci spustí hostitel aplikace, nevyžaduje se žádná konfigurace CORS.
.NET
.NET Aspire řídicí panel automaticky nakonfiguruje tak, aby umožňoval všechny zdroje prostředků.
Pokud se řídicí panel používá jako standlone, musí být CORS nakonfigurovaný ručně. Doména použitá k zobrazení aplikace prohlížeče musí být nakonfigurována jako povolený původ zadáním proměnné prostředí DASHBOARD__OTLP__CORS__ALLOWEDORIGINS při spuštění kontejneru řídicího panelu:
Předchozí příkaz spustí kontejner řídicího panelu a nakonfiguruje https://localhost:8080 jako povolený zdroj. To znamená, že aplikace prohlížeče, ke které se přistupuje pomocí https://localhost:8080, má oprávnění odesílat telemetrii řídicího panelu.
Více původů může být povoleno s hodnotou oddělenou čárkami. Nebo všechny zdroje mohou být povoleny se zástupným znakem *. Například DASHBOARD__OTLP__CORS__ALLOWEDORIGINS=*.
Koncové body OTLP řídicího panelu lze zabezpečit autentizací pomocí klíče rozhraní API. Pokud je tato možnost povolená, musí požadavky HTTP OTLP na řídicím panelu obsahovat klíč rozhraní API jako hlavičku x-otlp-api-key. Ve výchozím nastavení se při každém spuštění řídicího panelu vygeneruje nový klíč rozhraní API.
Při spuštění řídicího panelu z hostitele aplikace se automaticky povolí ověřování pomocí klíče rozhraní API. Ověřování řídicího panelu je možné zakázat nastavením DOTNET_DASHBOARD_UNSECURED_ALLOW_ANONYMOUS na true v souboru launchSettings.json hostitele aplikace.
Koncové body OTLP jsou ve výchozím nastavení na samostatném řídicím panelu nezabezpečené.
Konfigurace aplikace prohlížeče
Aplikace prohlížeče používá JavaScript OTEL SDK k odesílání telemetrie na řídicí panel. Úspěšné odesílání telemetrie na řídicí panel vyžaduje, aby sada SDK byla správně nakonfigurovaná.
Vývozce OTLP
Exportéry OTLP musí být součástí aplikace prohlížeče a nakonfigurované se sadou SDK. Export distribuovaného trasování pomocí OTLP například používá balíček @opentelemetry/export-trace-otlp-proto.
Při přidání OTLP do sady SDK je nutné zadat možnosti OTLP. Možnosti OTLP zahrnují:
url: Adresa, na kterou jsou provedeny požadavky HTTP OTLP. Adresa by měla být koncový bod HTTP OTLP řídicího panelu a cesta k rozhraní HTTP API OTLP. Například https://localhost:4318/v1/traces pro vývozce trasování OTLP. Pokud je aplikace prohlížeče spuštěna hostitelem aplikace, koncový bod HTTP OTLP je k dispozici z proměnné prostředí OTEL_EXPORTER_OTLP_ENDPOINT.
headers: Hlavičky odeslané s požadavky. Pokud je povolené ověřování klíče rozhraní API koncového bodu OTLP, musí být hlavička x-otlp-api-key odeslána s požadavky OTLP. Pokud je aplikace prohlížeče spuštěna hostitelem aplikace, klíč rozhraní API je k dispozici z proměnné prostředí OTEL_EXPORTER_OTLP_HEADERS.
Metadata prohlížeče
Pokud je aplikace prohlížeče nakonfigurovaná pro shromažďování distribuovaných tras, může nastavit trace parent pro jednotlivé úseky prohlížeče pomocí elementu meta v HTML. Hodnota metaelementu name="traceparent" by měla odpovídat aktuálnímu trasování.
V aplikaci .NET by se například hodnota nadřazeného trasování pravděpodobně přiřadila z Activity.Current a její hodnota Activity.Id by se předala jako content. Představte si například následující kód Razor:
<head>
@if (Activity.Current is { } currentActivity)
{
<meta name="traceparent" content="@currentActivity.Id" />
}
<!-- Other elements omitted for brevity... -->
</head>
Předchozí kód nastaví traceparent meta element na aktuální ID aktivity.
Příklad kódu telemetrie prohlížeče
Následující kód JavaScriptu ukazuje inicializaci sady OpenTelemetry JavaScript SDK a odesílání telemetrických dat na řídicí panel:
import { ConsoleSpanExporter, SimpleSpanProcessor } from '@opentelemetry/sdk-trace-base';
import { DocumentLoadInstrumentation } from '@opentelemetry/instrumentation-document-load';
import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-proto';
import { registerInstrumentations } from '@opentelemetry/instrumentation';
import { Resource } from '@opentelemetry/resources';
import { SemanticResourceAttributes } from '@opentelemetry/semantic-conventions';
import { WebTracerProvider } from '@opentelemetry/sdk-trace-web';
import { ZoneContextManager } from '@opentelemetry/context-zone';
export function initializeTelemetry(otlpUrl, headers, resourceAttributes) {
const otlpOptions = {
url: `${otlpUrl}/v1/traces`,
headers: parseDelimitedValues(headers)
};
const attributes = parseDelimitedValues(resourceAttributes);
attributes[SemanticResourceAttributes.SERVICE_NAME] = 'browser';
const provider = new WebTracerProvider({
resource: new Resource(attributes),
});
provider.addSpanProcessor(new SimpleSpanProcessor(new ConsoleSpanExporter()));
provider.addSpanProcessor(new SimpleSpanProcessor(new OTLPTraceExporter(otlpOptions)));
provider.register({
// Prefer ZoneContextManager: supports asynchronous operations
contextManager: new ZoneContextManager(),
});
// Registering instrumentations
registerInstrumentations({
instrumentations: [new DocumentLoadInstrumentation()],
});
}
function parseDelimitedValues(s) {
const headers = s.split(','); // Split by comma
const result = {};
headers.forEach(header => {
const [key, value] = header.split('='); // Split by equal sign
result[key.trim()] = value.trim(); // Add to the object, trimming spaces
});
return result;
}
Předchozí kód JavaScriptu definuje funkci initializeTelemetry, která očekává adresu URL koncového bodu OTLP, hlavičky a atributy prostředků. Tyto parametry poskytuje aplikace využívající prohlížeč, která je načítá z proměnných prostředí nastavených hostitelem aplikace. Představte si následující kód Razor:
Sdružování a minifikace kódu JavaScriptu je nad rámec tohoto článku.
Kompletní funkční příklad, jak nakonfigurovat sadu JavaScript OTEL SDK pro odesílání telemetrie na řídicí panel, najdete v ukázce prohlížečové telemetrie .
Zdroj tohoto obsahu najdete na GitHubu, kde můžete také vytvářet a kontrolovat problémy a žádosti o přijetí změn. Další informace najdete v našem průvodci pro přispěvatele.
Zpětná vazba k produktu .NET Aspire
.NET Aspire je open source projekt. Vyberte odkaz pro poskytnutí zpětné vazby:
V tomto modulu se dozvíte o použití telemetrie k zaznamenání chování aplikace nativní pro cloud a o tom, jak zásobník .NET Aspire usnadňuje ukládání dat a jejich pozdější zobrazení.