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>();
        }
    }
}

Результат теста:

Другие вопросы по тегам