Добавление настраиваемого столбца в таблицу Serilog в хранилище таблиц Azure для регистрации новой информации
Можно ли добавить новый столбец в таблицу Serilog в хранилище таблиц Azure для регистрации нового дополнительного поля, такого как идентификатор учетной записи или имя для входа?
Я думаю, что можно добавить новый столбец, но можно передать дополнительные поля в Serilog, как я сказал для новых добавленных столбцов? Как я могу определить это в Startup.cs или web.config? Спасибо
Это моя конфигурация в web.config:
<add key="serilog:using:AzureTableStorage" value="Serilog.Sinks.AzureTableStorage" />
<add key="serilog:write-to:AzureTableStorageWithProperties.connectionString" value="DefaultEndpointsProtocol=https;AccountName=MyAccountName;AccountKey=MyAccountKey;EndpointSuffix=core.windows.net" />
<add key="serilog:write-to:AzureTableStorage.formatter" value="Serilog.Formatting.Compact.CompactJsonFormatter, Serilog.Formatting.Compact" />
<add key="serilog:write-to:AzureTableStorageWithProperties.storageTableName" value="Serilog" />
Конфигурация startup.cs:
Log.Logger = new LoggerConfiguration()
.ReadFrom.AppSettings()
.CreateLogger();
1 ответ
Если вы хотите добавить дополнительные свойства при записи журнала в хранилище таблиц Azure с помощью Serilog, вам необходимо вызвать Enrich.FromLogContext()
а также LogContext.PushProperty
. С помощью этих двух методов ваше приложение добавит дополнительные свойства в таблицу Azure. Для более подробной информации, пожалуйста, обратитесь к документу
Например
- Установить SDK
Install-Package Serilog.Sinks.AzureTableStorage
Install-Package Serilog.Enrichers.Thread
- Код
static void Main(string[] args)
{
var storage =CloudStorageAccount.Parse("");
string tableName = "log";
var _log = new LoggerConfiguration()
.Enrich.FromLogContext()
.WriteTo.AzureTableStorageWithProperties(storage, LogEventLevel.Information, storageTableName: tableName, propertyColumns: new string[] { "AccountId" , "Name" }) ;
var logger = _log.CreateLogger();
var exampleuser = new User { AccountId = 3, Name = "Allen" };
LogContext.PushProperty("AccountId", exampleuser.AccountId);
logger.Information("{@User}", exampleuser);
exampleuser = new User { AccountId = 1, Name = "Jim" };
LogContext.PushProperty("AccountId", exampleuser.AccountId);
logger.Information("{@User}", exampleuser);
Console.ReadLine();
}
class User
{
public int AccountId { get; set; }
public string Name { get; set; }
}