mirror of
https://github.com/nsnail/Ocelot.git
synced 2025-06-19 22:08:17 +08:00
Feat/opentracing (#1243)
This commit is contained in:
@ -0,0 +1,21 @@
|
||||
<Project Sdk="Microsoft.NET.Sdk">
|
||||
|
||||
<PropertyGroup>
|
||||
<TargetFramework>netcoreapp3.1</TargetFramework>
|
||||
<Version>0.0.0-dev</Version>
|
||||
<Authors>Kjell-Åke Gafvelin</Authors>
|
||||
<Description>This package provides OpenTracing support to Ocelot.</Description>
|
||||
<PackageProjectUrl>https://github.com/ThreeMammals/Ocelot</PackageProjectUrl>
|
||||
<PackageTags>API Gateway;.NET core; OpenTracing</PackageTags>
|
||||
<GeneratePackageOnBuild>true</GeneratePackageOnBuild>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<PackageReference Include="OpenTracing" Version="0.12.1" />
|
||||
</ItemGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\Ocelot\Ocelot.csproj" />
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
15
src/Ocelot.Tracing.OpenTracing/OcelotBuilderExtensions.cs
Normal file
15
src/Ocelot.Tracing.OpenTracing/OcelotBuilderExtensions.cs
Normal file
@ -0,0 +1,15 @@
|
||||
namespace Ocelot.Tracing.OpenTracing
|
||||
{
|
||||
using Microsoft.Extensions.DependencyInjection.Extensions;
|
||||
using Ocelot.DependencyInjection;
|
||||
using Ocelot.Logging;
|
||||
|
||||
public static class OcelotBuilderExtensions
|
||||
{
|
||||
public static IOcelotBuilder AddOpenTracing(this IOcelotBuilder builder)
|
||||
{
|
||||
builder.Services.TryAddSingleton<ITracer, OpenTracingTracer>();
|
||||
return builder;
|
||||
}
|
||||
}
|
||||
}
|
75
src/Ocelot.Tracing.OpenTracing/OpenTracingTracer.cs
Normal file
75
src/Ocelot.Tracing.OpenTracing/OpenTracingTracer.cs
Normal file
@ -0,0 +1,75 @@
|
||||
namespace Ocelot.Tracing.OpenTracing
|
||||
{
|
||||
using global::OpenTracing;
|
||||
using global::OpenTracing.Propagation;
|
||||
using global::OpenTracing.Tag;
|
||||
using Microsoft.AspNetCore.Http;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Net.Http;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
class OpenTracingTracer : Logging.ITracer
|
||||
{
|
||||
private readonly ITracer _tracer;
|
||||
|
||||
public OpenTracingTracer(ITracer tracer)
|
||||
{
|
||||
_tracer = tracer ?? throw new ArgumentNullException(nameof(tracer));
|
||||
}
|
||||
|
||||
public void Event(HttpContext httpContext, string @event)
|
||||
{
|
||||
}
|
||||
|
||||
public async Task<HttpResponseMessage> SendAsync(HttpRequestMessage request,
|
||||
CancellationToken cancellationToken,
|
||||
Action<string> addTraceIdToRepo,
|
||||
Func<HttpRequestMessage,
|
||||
CancellationToken,
|
||||
Task<HttpResponseMessage>> baseSendAsync)
|
||||
{
|
||||
using (IScope scope = _tracer.BuildSpan(request.RequestUri.AbsoluteUri).StartActive(finishSpanOnDispose: true))
|
||||
{
|
||||
var span = scope.Span;
|
||||
|
||||
span.SetTag(Tags.SpanKind, Tags.SpanKindClient)
|
||||
.SetTag(Tags.HttpMethod, request.Method.Method)
|
||||
.SetTag(Tags.HttpUrl, request.RequestUri.OriginalString);
|
||||
|
||||
addTraceIdToRepo(span.Context.SpanId);
|
||||
|
||||
var headers = new Dictionary<string, string>();
|
||||
|
||||
_tracer.Inject(span.Context, BuiltinFormats.HttpHeaders, new TextMapInjectAdapter(headers));
|
||||
|
||||
foreach (var item in headers)
|
||||
{
|
||||
request.Headers.Add(item.Key, item.Value);
|
||||
}
|
||||
|
||||
try
|
||||
{
|
||||
var response = await baseSendAsync(request, cancellationToken);
|
||||
|
||||
span.SetTag(Tags.HttpStatus, (int)response.StatusCode);
|
||||
|
||||
return response;
|
||||
}
|
||||
catch (HttpRequestException ex)
|
||||
{
|
||||
Tags.Error.Set(scope.Span, true);
|
||||
|
||||
span.Log(new Dictionary<string, object>(3)
|
||||
{
|
||||
{ LogFields.Event, Tags.Error.Key },
|
||||
{ LogFields.ErrorKind, ex.GetType().Name },
|
||||
{ LogFields.ErrorObject, ex }
|
||||
});
|
||||
throw;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user