How to get Microsoft.Extensions.Logging in console application using Serilog and AutoFac?

前端 未结 3 1601
悲哀的现实
悲哀的现实 2021-02-12 14:31

We have common BL classes in a ASP.NET Core application that get in the ctor:

Microsoft.Extensions.Logging.ILogger

In ASP.NET Core, the i

3条回答
  •  我寻月下人不归
    2021-02-12 15:31

    Microsoft.Extensions.Logging (see source) is not part of ASP.NET Core and can run independently of it. All you need to do is to register the ILoggerFactory and ILogger<> interface.

    The ILoggerFactory is used by Logger to instantiate the actual logger.

    When using the Logging extension in console applications, its recommended still to use the IServiceCollection, as this allows you to use the IServiceCollection extension methods to register all packages which support this pattern.

    var services = new ServiceCollection();
    services.AddLogging();
    
    // Initialize Autofac
    var builder = new ContainerBuilder();
    // Use the Populate method to register services which were registered
    // to IServiceCollection
    builder.Populate(services);
    
    // Build the final container
    IContainer container = builder.Build();
    

    This is the recommended approach, as you won't have to think in detail which classes need to registered for libraries which have Microsoft.Extensions.DependencyInjection integration support.

    But of course you can also register it manually, but when a change happens to the Microsoft.Extensions.Logging library (new dependency added), you won't get it and first have to figure out or dig into the source code to find the error.

    builder.RegisterType()
        .As()
        .SingleInstance();
    builder.RegisterGeneric(typeof(Logger<>))
        .As(typeof(ILogger<>))
        .SingleInstance();
    

    All that remains is to register the logger types after the container has been built or before your application starts:

    var loggerFactory = container.Resolve();
    loggerFactory.AddConsole()
        .AddSerilog();
    

    and in your services inject ILogger as usual.

提交回复
热议问题