mirror of
https://github.com/nsnail/Ocelot.git
synced 2025-09-18 10:42:42 +08:00
wip
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>
|
17
src/Ocelot.Tracing.OpenTracing/OcelotBuilderExtensions.cs
Normal file
17
src/Ocelot.Tracing.OpenTracing/OcelotBuilderExtensions.cs
Normal file
@@ -0,0 +1,17 @@
|
||||
using Microsoft.Extensions.DependencyInjection;
|
||||
using Ocelot.DependencyInjection;
|
||||
using Ocelot.Logging;
|
||||
using System;
|
||||
|
||||
namespace Ocelot.Tracing.OpenTracing
|
||||
{
|
||||
public static class OcelotBuilderExtensions
|
||||
{
|
||||
public static IOcelotBuilder AddOpenTracing(this IOcelotBuilder builder)
|
||||
{
|
||||
builder.Services.AddSingleton<ITracer, OpenTracingTracer>();
|
||||
|
||||
return builder;
|
||||
}
|
||||
}
|
||||
}
|
71
src/Ocelot.Tracing.OpenTracing/OpenTracingTracer.cs
Normal file
71
src/Ocelot.Tracing.OpenTracing/OpenTracingTracer.cs
Normal file
@@ -0,0 +1,71 @@
|
||||
using Microsoft.AspNetCore.Http;
|
||||
using OpenTracing;
|
||||
using OpenTracing.Propagation;
|
||||
using OpenTracing.Tag;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Net.Http;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace Ocelot.Tracing.OpenTracing
|
||||
{
|
||||
class OpenTracingTracer : Logging.ITracer
|
||||
{
|
||||
private readonly ITracer tracer;
|
||||
|
||||
public OpenTracingTracer(ITracer tracer)
|
||||
{
|
||||
this.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 = this.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>();
|
||||
|
||||
this.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