-
Notifications
You must be signed in to change notification settings - Fork 1
/
Startup.cs
125 lines (105 loc) · 4.52 KB
/
Startup.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
using System;
using System.Diagnostics;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.HttpOverrides;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using Microsoft.OpenApi.Models;
using OpenTelemetry.Context.Propagation;
using OpenTelemetry.Trace;
using Serilog;
using TracingDemo.Protobuf;
namespace TracingDemo.WebApi
{
public class Startup
{
public Startup(IConfiguration configuration)
{
Configuration = configuration;
}
public IConfiguration Configuration { get; }
// This method gets called by the runtime. Use this method to add services to the container.
public void ConfigureServices(IServiceCollection services)
{
services.Configure<ForwardedHeadersOptions>(
options => options.ForwardedHeaders = ForwardedHeaders.All
);
services.AddHealthChecks();
services.AddControllers();
// This switch must be set before creating the GrpcChannel/HttpClient.
// This allows the app to call gRPC services it thinks are not secure, mTLS is provided by Linkerd.
AppContext.SetSwitch("System.Net.Http.SocketsHttpHandler.Http2UnencryptedSupport", true);
services.AddHttpClient();
// add Typed Grpc Client
services.AddGrpcClient<Greeter.GreeterClient>(options =>
{
options.Address = new Uri(Configuration["Services:Greeter"]);
});
// Register the Swagger generator, defining 1 or more Swagger documents
services.AddSwaggerGen(c =>
{
c.SwaggerDoc("v1", new OpenApiInfo { Title = Program.Name, Version = "1.0" });
});
// create and register an activity source
var activitySource = new ActivitySource(Program.Name);
services.AddSingleton(activitySource);
// TextFormat Defaults to W3C - Enable B3 via configuration
string tracingFormat = Configuration["Tracing:Format"]?.ToLowerInvariant();
if (tracingFormat == "b3m") // B3 (multi) headers come from Nginx
OpenTelemetry.Sdk.SetDefaultTextMapPropagator(new B3Propagator(singleHeader: false));
else if (tracingFormat == "b3s")
OpenTelemetry.Sdk.SetDefaultTextMapPropagator(new B3Propagator(singleHeader: true));
// Configure OpenTelemetry
services.AddOpenTelemetryTracing(builder =>
{
// register the activity source
builder.AddSource(activitySource.Name);
// Add ASP.Net Core Request Handling
builder.AddAspNetCoreInstrumentation();
// Add gRPC Propagation
builder.AddGrpcClientInstrumentation();
// export to Zipkin receiver
string zipkinUrl = Configuration.GetConnectionString("Telemetry");
if (!string.IsNullOrEmpty(zipkinUrl))
{
builder.AddZipkinExporter(options =>
{
options.ServiceName = Program.Name;
options.Endpoint = new Uri(zipkinUrl);
});
}
// enable console output by configuration
if (Configuration.GetValue<bool>("Tracing:Console", false))
builder.AddConsoleExporter();
});
}
// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
app.UseRouting();
app.UseSerilogRequestLogging();
app.UseSwagger();
app.UseSwaggerUI(c =>
{
c.SwaggerEndpoint("/swagger/v1/swagger.json", Program.Name);
c.RoutePrefix = "api/swagger";
});
app.UseEndpoints(endpoints =>
{
endpoints.MapHealthChecks("/healthz");
endpoints.MapControllers();
endpoints.MapGet("/", async context =>
{
context.Response.Redirect("/api/swagger/index.html");
await context.Response.CompleteAsync();
});
});
}
}
}