Регистрация и настройка для консольного приложения .Net core 2.0?
Следующий код получил ошибки. Каков правильный способ настройки ведения журнала и управления конфигурацией для консольного приложения .Net Core 2.0?
Ошибка CS1061 "LoggerFactory" не содержит определения для "AddConsole", и не может быть найден метод расширения "AddConsole", принимающий первый аргумент типа "LoggerFactory" (вам не хватает директивы using или ссылки на сборку?)
Ошибка CS1503 Аргумент 2: невозможно преобразовать из "Microsoft.Extensions.Configuration.IConfigurationSection" в "System.Action"
class Program
{
static void Main(string[] args)
{
var services = new ServiceCollection();
ConfigureServices(services);
var serviceProvider = services.BuildServiceProvider();
var app = serviceProvider.GetService<Application>();
Task.Run(() => app.Run()).Wait();
}
private static void ConfigureServices(IServiceCollection services)
{
ILoggerFactory loggerFactory = new LoggerFactory()
.AddConsole() // Error!
.AddDebug();
services.AddSingleton(loggerFactory); // Add first my already configured instance
services.AddLogging(); // Allow ILogger<T>
IConfigurationRoot configuration = GetConfiguration();
services.AddSingleton<IConfigurationRoot>(configuration);
// Support typed Options
services.AddOptions();
services.Configure<MyOptions>(configuration.GetSection("MyOptions")); // Error!
services.AddTransient<Application>();
}
private static IConfigurationRoot GetConfiguration()
{
return new ConfigurationBuilder().SetBasePath(Directory.GetCurrentDirectory()).AddXmlFile("App.config", optional: true).Build();
}
public class MyOptions
{
public string Name { get; set; }
}
public class Application
{
ILogger _logger;
MyOptions _settings;
public Application(ILogger<Application> logger, IOptions<MyOptions> settings)
{
_logger = logger;
_settings = settings.Value;
}
public async Task Run()
{
try
{
_logger.LogInformation($"This is a console application for {_settings.Name}");
}
catch (Exception ex)
{
_logger.LogError(ex.ToString());
}
}
}
}
Ответы
Ответ 1
Похоже, вы можете потерять пару зависимостей:
С точки зрения настройки сервисов в исполняемых файлах .NET Core, Andrew Lock имеет сообщение по теме для первой версии .NET Core, Некоторые из них могут быть устаревшими сейчас с недавним прибытием .NET Core 2, но это стоит прочитать.
Ответ 2
Опираясь на ответ Кирка Ларкинса (убедитесь, что у вас установлены пакеты nuget, Microsoft.Extensions.Options.ConfigurationExtensions
, Microsoft.Extensions.Logging.Console
и Microsoft.Extensions.Logging.Debug
), вы можете упростить настройку регистрации и пропустить объявление из loggerFactory, передавая ILoggerBuilder
в .AddLogging()
:
public static IServiceProvider ConfigureServices(IServiceCollection serviceCollection)
{
//ILoggerFactory loggerFactory = new LoggerFactory()
// .AddConsole()
// .AddDebug();
serviceCollection
.AddLogging(opt =>
{
opt.AddConsole();
opt.AddDebug();
})
.AddTransient<IFooService, FooService>();
/*... rest of config */
var serviceProvider = serviceCollection.BuildServiceProvider();
return serviceProvider;
}