Microsoft Extension Framework добавляет настраиваемые параметры в регистратор вместо каждого вызова?
У меня есть лазурная функция:
public void Run([TimerTrigger("0 0 0 * * *", RunOnStartup =true)]TimerInfo myTimer, ILogger log)
{
using (logger.BeginScope(properties))
{
logger.LogTrace(message);
}
}
Dictionary<string, object> _props = new Dictionary<string, object> { { "service", "exchange.rates.procces" } };
Как видите, я добавляю настраиваемые свойства, предоставляя словарь (свойства) для BeginScope. Есть ли способ добавить словарь в регистратор, чтобы мне не приходилось предоставлять словарь для каждого вызова? Регистратор записывает в Application Insigths.
1 ответ
Решение
Чтобы добавить пользовательские измерения, вы можете использовать ITelemetryInitializer для своей функции azure.
После написания собственного ITelemetryInitializer вам необходимо зарегистрировать его в функции azure. См. Пример кода ниже:
using Microsoft.ApplicationInsights.Channel;
using Microsoft.ApplicationInsights.Extensibility;
using Microsoft.Azure.WebJobs;
using Microsoft.Azure.WebJobs.Hosting;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using System;
//add thie line of code before namespace
[assembly: WebJobsStartup(typeof(FunctionApp2.MyStartup))]
namespace FunctionApp2
{
public class Function1
{
[FunctionName("Function1")]
public void Run([TimerTrigger("0 */1 * * * *")]TimerInfo myTimer, ILogger log)
{
log.LogInformation($"C# Timer trigger function executed at: {DateTime.Now}");
log.LogInformation("333 this is a test message...");
}
}
//define your custom ITelemetryInitializer which is used to add custom dimension
internal class MyTelemetryInitializer : ITelemetryInitializer
{
public void Initialize(ITelemetry telemetry)
{
if (telemetry != null && !telemetry.Context.GlobalProperties.ContainsKey("my_custom_dimen22"))
{
telemetry.Context.GlobalProperties.Add("my_custom_dimen22", "Hello, this is custom dimension for request!!!");
}
}
}
//register your custom ITelemetryInitializer
public class MyStartup : IWebJobsStartup
{
public void Configure(IWebJobsBuilder builder)
{
builder.Services.AddSingleton<ITelemetryInitializer, MyTelemetryInitializer>();
}
}
}
Результат теста: