From 53c135ce0cc11a41ab75dd39a8a549bdd924dfca Mon Sep 17 00:00:00 2001 From: Rolf Kristensen Date: Wed, 13 Sep 2023 19:55:43 +0200 Subject: [PATCH] NLogLoggerFactory - Optimize concurrency for CreateLogger --- .../Logging/NLogLoggerFactory.cs | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/src/NLog.Extensions.Logging/Logging/NLogLoggerFactory.cs b/src/NLog.Extensions.Logging/Logging/NLogLoggerFactory.cs index 8753a336..a9400ed3 100644 --- a/src/NLog.Extensions.Logging/Logging/NLogLoggerFactory.cs +++ b/src/NLog.Extensions.Logging/Logging/NLogLoggerFactory.cs @@ -1,5 +1,5 @@ using System; -using System.Collections.Generic; +using System.Collections.Concurrent; using Microsoft.Extensions.Logging; using NLog.Common; @@ -10,7 +10,7 @@ namespace NLog.Extensions.Logging /// public class NLogLoggerFactory : ILoggerFactory { - private readonly Dictionary _loggers = new Dictionary(StringComparer.Ordinal); + private readonly ConcurrentDictionary _loggers = new ConcurrentDictionary(StringComparer.Ordinal); private readonly NLogLoggerProvider _provider; @@ -68,15 +68,18 @@ protected virtual void Dispose(bool disposing) /// The . public Microsoft.Extensions.Logging.ILogger CreateLogger(string categoryName) { - lock (_loggers) + if (!_loggers.TryGetValue(categoryName, out var logger)) { - if (!_loggers.TryGetValue(categoryName, out var logger)) + lock (_loggers) { - logger = _provider.CreateLogger(categoryName); - _loggers[categoryName] = logger; + if (!_loggers.TryGetValue(categoryName, out logger)) + { + logger = _provider.CreateLogger(categoryName); + _loggers[categoryName] = logger; + } } - return logger; } + return logger; } ///