From ef0367cb7a67b82e7330ae98045bc3e905da83f0 Mon Sep 17 00:00:00 2001 From: Teo Voinea <58236992+tevoinea@users.noreply.github.com> Date: Mon, 15 Aug 2022 10:42:24 -0400 Subject: [PATCH] Make log sinks a singleton (#2247) * Make log sinks a singleton, continue passing new log tracer for every invocation * Remove no longer used code --- src/ApiService/ApiService/Log.cs | 24 ++++++++++++++++++++++++ src/ApiService/ApiService/Program.cs | 20 +++----------------- 2 files changed, 27 insertions(+), 17 deletions(-) diff --git a/src/ApiService/ApiService/Log.cs b/src/ApiService/ApiService/Log.cs index 7a953f905c..335a6dc623 100644 --- a/src/ApiService/ApiService/Log.cs +++ b/src/ApiService/ApiService/Log.cs @@ -276,3 +276,27 @@ public LogTracer CreateLogTracer(Guid correlationId, IEnumerable<(string, string } } + +public interface ILogSinks { + List GetLogSinks(); +} + +public class LogSinks : ILogSinks { + private readonly List _loggers; + + public LogSinks(IServiceConfig config) { + _loggers = new List(); + foreach (var dest in config.LogDestinations) { + _loggers.Add( + dest switch { + LogDestination.AppInsights => new AppInsights(config.ApplicationInsightsInstrumentationKey!), + LogDestination.Console => new Console(), + _ => throw new Exception($"Unhandled Log Destination type: {dest}"), + } + ); + } + } + public List GetLogSinks() { + return _loggers; + } +} diff --git a/src/ApiService/ApiService/Program.cs b/src/ApiService/ApiService/Program.cs index 8f4c114e6b..b04dbd7458 100644 --- a/src/ApiService/ApiService/Program.cs +++ b/src/ApiService/ApiService/Program.cs @@ -36,22 +36,6 @@ public async Async.Task Invoke(FunctionContext context, FunctionExecutionDelegat } } - - public static List GetLoggers(IServiceConfig config) { - List loggers = new List(); - foreach (var dest in config.LogDestinations) { - loggers.Add( - dest switch { - LogDestination.AppInsights => new AppInsights(config.ApplicationInsightsInstrumentationKey!), - LogDestination.Console => new Console(), - _ => throw new Exception($"Unhandled Log Destination type: {dest}"), - } - ); - } - return loggers; - } - - //Move out expensive resources into separate class, and add those as Singleton // ArmClient, Table Client(s), Queue Client(s), HttpClient, etc. public async static Async.Task Main() { @@ -72,8 +56,9 @@ public async static Async.Task Main() { services .AddScoped(s => { + var logSinks = s.GetRequiredService(); var cfg = s.GetRequiredService(); - return new LogTracerFactory(GetLoggers(cfg)) + return new LogTracerFactory(logSinks.GetLogSinks()) .CreateLogTracer( Guid.Empty, severityLevel: cfg.LogSeverityLevel); @@ -118,6 +103,7 @@ public async static Async.Task Main() { .AddSingleton() .AddSingleton() .AddSingleton() + .AddSingleton() .AddHttpClient() .AddMemoryCache(); }