Microsoft.Extensions.Logging.Abstractions 10.0.2

About

Microsoft.Extensions.Logging.Abstractions provides abstractions of logging. Interfaces defined in this package are implemented by classes in Microsoft.Extensions.Logging and other logging packages.

This package includes a logging source generator that produces highly efficient and optimized code for logging message methods.

Key Features

  • Define main logging abstraction interfaces like ILogger, ILoggerFactory, ILoggerProvider, etc.

How to Use

Custom logger provider implementation example

using Microsoft.Extensions.Logging;

public sealed class ColorConsoleLogger : ILogger
{
    private readonly string _name;
    private readonly Func<ColorConsoleLoggerConfiguration> _getCurrentConfig;

    public ColorConsoleLogger(
        string name,
        Func<ColorConsoleLoggerConfiguration> getCurrentConfig) =>
        (_name, _getCurrentConfig) = (name, getCurrentConfig);

    public IDisposable? BeginScope<TState>(TState state) where TState : notnull => default!;

    public bool IsEnabled(LogLevel logLevel) =>
        _getCurrentConfig().LogLevelToColorMap.ContainsKey(logLevel);

    public void Log<TState>(
        LogLevel logLevel,
        EventId eventId,
        TState state,
        Exception? exception,
        Func<TState, Exception?, string> formatter)
    {
        if (!IsEnabled(logLevel))
        {
            return;
        }

        ColorConsoleLoggerConfiguration config = _getCurrentConfig();
        if (config.EventId == 0 || config.EventId == eventId.Id)
        {
            ConsoleColor originalColor = Console.ForegroundColor;

            Console.ForegroundColor = config.LogLevelToColorMap[logLevel];
            Console.WriteLine($"[{eventId.Id,2}: {logLevel,-12}]");

            Console.ForegroundColor = originalColor;
            Console.Write($"     {_name} - ");

            Console.ForegroundColor = config.LogLevelToColorMap[logLevel];
            Console.Write($"{formatter(state, exception)}");

            Console.ForegroundColor = originalColor;
            Console.WriteLine();
        }
    }
}

Create logs


// Worker class that uses logger implementation of teh interface ILogger<T>

public sealed class Worker : BackgroundService
{
    private readonly ILogger<Worker> _logger;

    public Worker(ILogger<Worker> logger) =>
        _logger = logger;

    protected override async Task ExecuteAsync(CancellationToken stoppingToken)
    {
        while (!stoppingToken.IsCancellationRequested)
        {
            _logger.LogInformation("Worker running at: {time}", DateTimeOffset.UtcNow);
            await Task.Delay(1_000, stoppingToken);
        }
    }
}

Use source generator

public static partial class Log
{
    [LoggerMessage(
        EventId = 0,
        Level = LogLevel.Critical,
        Message = "Could not open socket to `{hostName}`")]
    public static partial void CouldNotOpenSocket(this ILogger logger, string hostName);
}

public partial class InstanceLoggingExample
{
    private readonly ILogger _logger;

    public InstanceLoggingExample(ILogger logger)
    {
        _logger = logger;
    }

    [LoggerMessage(
        EventId = 0,
        Level = LogLevel.Critical,
        Message = "Could not open socket to `{hostName}`")]
    public partial void CouldNotOpenSocket(string hostName);
}

Main Types

The main types provided by this library are:

  • Microsoft.Extensions.Logging.ILogger
  • Microsoft.Extensions.Logging.ILoggerProvider
  • Microsoft.Extensions.Logging.ILoggerFactory
  • Microsoft.Extensions.Logging.ILogger<TCategoryName>
  • Microsoft.Extensions.Logging.LogLevel
  • Microsoft.Extensions.Logging.Logger<T>
  • Microsoft.Extensions.Logging.LoggerMessage
  • Microsoft.Extensions.Logging.Abstractions.NullLogger

Additional Documentation

Microsoft.Extensions.Logging Microsoft.Extensions.Logging.Console Microsoft.Extensions.Logging.Debug Microsoft.Extensions.Logging.EventSource Microsoft.Extensions.Logging.EventLog Microsoft.Extensions.Logging.TraceSource

Feedback & Contributing

Microsoft.Extensions.Logging.Abstractions is released as open source under the MIT license. Bug reports and contributions are welcome at the GitHub repository.

Showing the top 20 packages that depend on Microsoft.Extensions.Logging.Abstractions.

Packages Downloads
Microsoft.CodeAnalysis.Workspaces.MSBuild
.NET Compiler Platform ("Roslyn") support for analyzing MSBuild projects and solutions. This should be used with at least one of the following packages to add the appropriate language support: - Microsoft.CodeAnalysis.CSharp.Workspaces - Microsoft.CodeAnalysis.VisualBasic.Workspaces More details at https://aka.ms/roslyn-packages This package was built from the source at https://github.com/dotnet/roslyn/commit/fa72fa61b0d822ea8a3fbeb96f668340419ab5cd.
25
Microsoft.AspNet.DataProtection
ASP.NET 5 logic to protect and unprotect data, similar to DPAPI.
23
Npgsql
Npgsql is the open source .NET data provider for PostgreSQL.
20
WebApiClient.JIT
一款基于HttpClient封装,只需要定义c#接口并修饰相关特性,即可异步调用远程http接口的客户端库
19
WebApiClient.JIT
一款基于HttpClient封装,只需要定义c#接口并修饰相关特性,即可异步调用远程http接口的客户端库
18
Microsoft.Extensions.Localization
Application localization services and default implementation based on ResourceManager to load localized assembly resources. This package was built from the source code at https://github.com/dotnet/aspnetcore/tree/ed74665e773dd1ebea3289c5662d71c590305932
18
YesSql.Abstractions
Package Description
18
Microsoft.Extensions.Logging.AzureAppServices
Logger implementation to support Azure App Services 'Diagnostics logs' and 'Log stream' features. This package was built from the source code at https://github.com/dotnet/aspnetcore/tree/96103c264e5e8f0485d07018ba27b78cd8227dd2
18
Npgsql
Npgsql is the open source .NET data provider for PostgreSQL.
18
NLog.Extensions.Logging
NLog provider for Microsoft.Extensions.Logging for usage in .NET Standard libraries and console applicaties. For ASP.NET Core, use NLog.Web.AspNetCore: https://www.nuget.org/packages/NLog.Web.AspNetCore
18
Npgsql
Npgsql is the open source .NET data provider for PostgreSQL.
17
Microsoft.Extensions.Logging.AzureAppServices
Logger implementation to support Azure App Services 'Diagnostics logs' and 'Log stream' features. This package was built from the source code at https://github.com/dotnet/aspnetcore/tree/8899cb30120d41413065f1b1465cdabefe0a1f9c
17
Microsoft.Extensions.Logging.AzureAppServices
Logger implementation to support Azure App Services 'Diagnostics logs' and 'Log stream' features. This package was built from the source code at https://github.com/dotnet/aspnetcore/tree/fedc545ce86467b7d3413d906f1ab02fb3db12ff
17
NLog.Extensions.Logging
NLog LoggerProvider for Microsoft.Extensions.Logging for logging in .NET Standard libraries and .NET Core applications. For ASP.NET Core, check: https://www.nuget.org/packages/NLog.Web.AspNetCore
17
Npgsql
Npgsql is the open source .NET data provider for PostgreSQL.
16
Blazorise.Components
Blazorise is a component library built on top of Blazor and CSS frameworks like Bootstrap, Bulma and Material.
16
Microsoft.Extensions.Logging.Console
Console logger provider implementation for Microsoft.Extensions.Logging.
16
YesSql.Abstractions
Package Description
16
Microsoft.AspNetCore.Server.Kestrel.Transport.Libuv
Libuv transport for the ASP.NET Core Kestrel cross-platform web server. This package was built from the source code at https://github.com/aspnet/AspNetCore/tree/c5f85986e62dabfc0b7f2f2a45dc7c22e8ac815f
16

https://go.microsoft.com/fwlink/?LinkID=799421

Version Downloads Last updated
11.0.0-preview.2.26159.112 1 2026/3/13
11.0.0-preview.1.26104.118 2 2026/2/17
10.0.5 1 2026/3/15
10.0.4 1 2026/3/12
10.0.3 1 2026/2/18
10.0.2 2 2026/2/10
10.0.1 2 2025/12/30
10.0.0 5 2025/11/12
10.0.0-rc.2.25502.107 5 2025/10/29
10.0.0-rc.1.25451.107 8 2025/9/26
10.0.0-preview.7.25380.108 5 2025/10/9
10.0.0-preview.6.25358.103 5 2025/10/9
10.0.0-preview.5.25277.114 3 2025/6/10
10.0.0-preview.4.25258.110 6 2025/5/25
10.0.0-preview.3.25171.5 2 2025/5/26
10.0.0-preview.2.25163.2 4 2025/5/26
10.0.0-preview.1.25080.5 1 2025/5/26
9.0.14 1 2026/3/13
9.0.13 2 2026/2/19
9.0.12 3 2026/2/6
9.0.11 4 2025/11/12
9.0.10 5 2025/11/4
9.0.9 6 2025/10/9
9.0.8 5 2025/10/9
9.0.7 6 2025/10/9
9.0.6 3 2025/6/16
9.0.5 5 2025/5/25
9.0.4 2 2025/5/27
9.0.3 5 2025/5/26
9.0.2 2 2025/5/25
9.0.1 2 2025/5/26
9.0.0 13 2025/5/26
9.0.0-rc.2.24473.5 2 2025/5/26
9.0.0-rc.1.24431.7 2 2025/5/26
9.0.0-preview.7.24405.7 4 2025/5/26
9.0.0-preview.6.24327.7 2 2025/5/26
9.0.0-preview.5.24306.7 1 2025/5/26
9.0.0-preview.4.24266.19 1 2025/5/27
9.0.0-preview.3.24172.9 2 2025/5/26
9.0.0-preview.2.24128.5 2 2025/5/26
9.0.0-preview.1.24080.9 2 2025/5/26
8.0.3 2 2025/5/26
8.0.2 2 2025/5/27
8.0.1 3 2025/4/17
8.0.0 3 2025/4/17
8.0.0-rc.2.23479.6 2 2025/5/26
8.0.0-rc.1.23419.4 6 2025/5/26
8.0.0-preview.7.23375.6 6 2025/5/26
8.0.0-preview.6.23329.7 5 2025/5/26
8.0.0-preview.5.23280.8 7 2025/5/26
8.0.0-preview.4.23259.5 7 2025/5/26
8.0.0-preview.3.23174.8 5 2025/5/26
8.0.0-preview.2.23128.3 4 2025/5/26
8.0.0-preview.1.23110.8 7 2025/5/26
7.0.1 7 2025/5/26
7.0.0 4 2025/4/17
7.0.0-rc.2.22472.3 5 2025/5/26
7.0.0-rc.1.22426.10 6 2025/5/26
7.0.0-preview.7.22375.6 4 2025/5/26
7.0.0-preview.6.22324.4 6 2025/5/26
7.0.0-preview.5.22301.12 8 2025/5/26
7.0.0-preview.4.22229.4 5 2025/5/26
7.0.0-preview.3.22175.4 6 2025/5/26
7.0.0-preview.2.22152.2 9 2025/5/26
7.0.0-preview.1.22076.8 5 2025/5/26
6.0.4 7 2025/5/26
6.0.3 6 2025/5/26
6.0.2 5 2025/5/26
6.0.2-mauipre.1.22054.8 3 2025/12/25
6.0.1 5 2025/4/17
6.0.0 9 2025/5/26
6.0.0-rc.2.21480.5 7 2025/5/26
6.0.0-rc.1.21451.13 12 2025/5/27
6.0.0-preview.7.21377.19 7 2025/5/26
6.0.0-preview.6.21352.12 7 2025/5/26
6.0.0-preview.5.21301.5 6 2025/5/26
6.0.0-preview.4.21253.7 5 2025/5/26
6.0.0-preview.3.21201.4 5 2025/5/26
6.0.0-preview.2.21154.6 4 2025/6/6
6.0.0-preview.1.21102.12 6 2025/5/26
5.0.0 7 2025/5/26
5.0.0-rc.2.20475.5 7 2025/5/27
5.0.0-rc.1.20451.14 6 2025/5/26
5.0.0-preview.8.20407.11 5 2025/5/26
5.0.0-preview.7.20364.11 6 2025/5/26
5.0.0-preview.6.20305.6 5 2025/5/27
5.0.0-preview.5.20278.1 7 2025/5/26
5.0.0-preview.4.20251.6 6 2025/5/26
5.0.0-preview.3.20215.2 7 2025/5/26
5.0.0-preview.2.20160.3 6 2025/5/26
5.0.0-preview.1.20120.4 6 2025/5/26
3.1.32 4 2025/5/26
3.1.31 5 2025/5/26
3.1.30 6 2025/5/26
3.1.29 9 2025/5/26
3.1.28 7 2025/5/26
3.1.27 7 2025/5/26
3.1.26 6 2025/5/27
3.1.25 6 2025/5/26
3.1.24 5 2025/5/26
3.1.23 7 2025/5/27
3.1.22 9 2025/5/26
3.1.21 8 2025/5/26
3.1.20 7 2025/5/26
3.1.19 6 2025/5/26
3.1.18 6 2025/5/26
3.1.17 6 2025/5/26
3.1.16 6 2025/5/26
3.1.15 6 2025/5/26
3.1.14 5 2025/5/26
3.1.13 6 2025/5/26
3.1.12 6 2025/5/26
3.1.11 5 2025/5/26
3.1.10 8 2025/5/26
3.1.9 5 2025/5/26
3.1.8 5 2025/5/27
3.1.7 6 2025/5/26
3.1.6 6 2025/5/26
3.1.5 6 2025/5/26
3.1.4 8 2025/5/26
3.1.3 7 2025/5/26
3.1.2 5 2025/5/26
3.1.1 7 2025/5/26
3.1.0 6 2025/5/26
3.1.0-preview3.19553.2 6 2025/5/26
3.1.0-preview2.19525.4 6 2025/5/26
3.1.0-preview1.19506.1 5 2025/5/26
3.0.3 10 2025/5/27
3.0.2 7 2025/5/26
3.0.1 5 2025/5/26
3.0.0 4 2025/5/26
3.0.0-rc1.19456.10 4 2025/5/26
3.0.0-preview9.19423.4 7 2025/5/26
3.0.0-preview8.19405.4 6 2025/5/26
3.0.0-preview7.19362.4 8 2025/5/26
3.0.0-preview6.19304.6 8 2025/5/26
3.0.0-preview5.19227.9 6 2025/5/26
3.0.0-preview4.19216.2 4 2025/5/26
3.0.0-preview3.19153.1 7 2025/5/26
3.0.0-preview.19074.2 5 2025/5/26
3.0.0-preview.18572.1 6 2025/5/26
2.2.0 11 2025/4/17
2.2.0-preview3-35497 7 2025/5/26
2.2.0-preview2-35157 6 2025/5/26
2.2.0-preview1-35029 5 2025/5/26
2.1.1 7 2025/5/26
2.1.0 7 2025/5/26
2.1.0-rc1-final 9 2025/5/25
2.1.0-preview2-final 5 2025/5/26
2.1.0-preview1-final 7 2025/5/26
2.0.2 8 2025/5/26
2.0.1 7 2025/5/26
2.0.0 8 2025/4/17
2.0.0-preview2-final 5 2025/5/26
2.0.0-preview1-final 4 2025/10/9
1.1.2 7 2025/5/26
1.1.1 8 2025/5/27
1.1.0 5 2025/5/26
1.1.0-preview1-final 5 2025/5/26
1.0.2 8 2025/5/26
1.0.1 6 2025/5/26
1.0.0 5 2025/5/26
1.0.0-rc2-final 6 2025/5/26
1.0.0-rc1-final 6 2025/5/26