Чтение онлайн

ЖАНРЫ

Язык программирования C#9 и платформа .NET5
Шрифт:

restrictedToMinimumLevel);

var sqlOptions = new MSSqlServerSinkOptions

{

AutoCreateSqlTable = false,

SchemaName = schema,

TableName = tableName,

};

if (hostingContext.HostingEnvironment.IsDevelopment)

{

sqlOptions.BatchPeriod = new TimeSpan(0, 0, 0, 1);

sqlOptions.BatchPostingLimit = 1;

}

loggerConfiguration

.Enrich.FromLogContext

.Enrich.WithMachineName

.WriteTo.File(

path: "ErrorLog.txt",

rollingInterval: RollingInterval.Day,

restrictedToMinimumLevel: logLevel,

outputTemplate: OutputTemplate)

.WriteTo.Console(restrictedToMinimumLevel: logLevel)

.WriteTo.MSSqlServer(

connectionString: connectionString,

sqlOptions,

restrictedToMinimumLevel: level,

columnOptions: ColumnOptions);

});

return builder;

}

Теперь,

когда все готово, пора заменить стандартное средство ведения журнала на Serilog.

Обновление настроек приложения

Раздел

Logging
во всех файлах настроек приложения (
appsettings.json
,
appsettings.development.json
и
appsettings.production
) для проектов
AutoLot.Api
и
AutoLot.Dal
потребуется модифицировать с учетом новой информации о ведении журнала и добавить имя приложения.

Откройте файлы

appsettings.json
и обновите размертку JSON, как показано ниже; удостоверьтесь в том, что применяете корректное имя проекта в узле
ApplicationName
и указываете строку подключения, соответствующую вашей системе:

// appsettings.json

{

"Logging": {

"MSSqlServer": {

"schema": "Logging",

"tableName": "SeriLogs",

"restrictedToMinimumLevel": "Warning"

}

},

"ApplicationName": "AutoLot.Api",

"AllowedHosts": "*"

}

// appsettings.development.json

{

"Logging": {

"MSSqlServer": {

"schema": "Logging",

"tableName": "SeriLogs",

"restrictedToMinimumLevel": "Warning"

}

},

"RebuildDataBase": false,

"ApplicationName": "AutoLot.Api - Dev",

"ConnectionStrings": {

"AutoLot": "Server=.,5433;Database=AutoLot;User ID=sa;Password=P@ssw0rd;"

}

}

// appsettings.production.json

{

"Logging": {

"MSSqlServer": {

"schema": "Logging",

"tableName": "SeriLogs",

"restrictedToMinimumLevel": "Warning"

}

},

"RebuildDataBase": false,

"ApplicationName": "AutoLot.Api - Prod",

"ConnectionStrings": {

"AutoLot": "It's a secret"

}

}

Обновление Program.cs

Добавьте

в файлы Program.cs в проектах
AutoLot.Api
и
AutoLot.Mvc
следующий оператор
using
:

using AutoLot.Services.Logging;

Модифицируйте метод

CreateHostBuilder
в обоих проектах, как показано ниже:

public static IHostBuilder CreateHostBuilder(string[] args) =>

Host.CreateDefaultBuilder(args)

.ConfigureWebHostDefaults(webBuilder =>

{

webBuilder.UseStartup<Startup>;

}).ConfigureSerilog;

Обновление Startup.cs

Добавьте в файлы

Startup.cs
в проектах
AutoLot.Api
и
AutoLot.Mvc
следующий оператор
using
:

using AutoLot.Services.Logging;

Затем необходимо поместить новые интерфейсы ведения журнала в контейнер DI. Добавьте в метод

ConfigureServices
в обоих проектах такой код:

services.AddScoped(typeof(IAppLogging<>), typeof(AppLogging<>));

Обновление контроллера

Следующее обновление связано с заменой ссылок на

ILogger
ссылками на
IAppLogging
. Начните с класса
WeatherForecastController
в проекте
AutoLot.Api
. Добавьте в класс следующий оператор
using
:

Поделиться с друзьями: