在Azure webJob中使用ILogger进行DI

时间:2018-09-20 09:14:15

标签: c# azure-webjobs azure-application-insights loggerfactory

我在.net framework 4.6中创建了一个Azure Webjob项目。我正在尝试使用ILogger实现依赖项注入,并在应用程序见解中记录信息。

class Program
{
    private static IConfigurationRoot configuration;

    // Please set the following connection strings in app.config for this WebJob to run:
    // AzureWebJobsDashboard and AzureWebJobsStorage
    public static void Main()
    {
        var config = new JobHostConfiguration();

        if (config.IsDevelopment)
        {
            config.UseDevelopmentSettings();
        }
        var builder = new ConfigurationBuilder()
                      .SetBasePath(Directory.GetCurrentDirectory())
                      .AddJsonFile("appsettings.json", optional: false, reloadOnChange: true)
                      .AddEnvironmentVariables();

        IServiceCollection serviceCollection = new ServiceCollection();
        ConfigureServices(serviceCollection);
        //config.JobActivator = new CustomJobActivator(serviceCollection.BuildServiceProvider());
        config.LoggerFactory = new LoggerFactory()
           .AddApplicationInsights(configuration.GetSection("ApplicationInsights")["InstrumentationKey"], null);
        config.UseTimers();
        var host = new JobHost(config);
        // The following code ensures that the WebJob will be running continuously
        host.RunAndBlock();
    }

    private static void ConfigureServices(IServiceCollection serviceCollection)
    {
        serviceCollection.AddTransient<Functions, Functions>();
        serviceCollection.AddLogging();
    }
}

appSettings.json

{   
    "ApplicationInsights": {
        "InstrumentationKey": "8028437c-888-666-444-2cf3777106a8"
    }
}

Functions.cs

public class Functions
{
    private readonly ILogger<Functions> _logger;

    public Functions(ILogger<Functions> logger)
    {
        _logger = logger;
    }

    public void ProcessTimerMessage([TimerTrigger("0 */5 * * * *")]TimerInfo timerInfo, TextWriter log)
    {
        //LOG THIS IN APP INSIGHTS
        _logger.LogError("Error");
    }
}

我也尝试过在ConfigureServices方法中添加以下代码。但是仍然没有运气。

var telemetryClient = new TelemetryClient(new TelemetryConfiguration()
{
       InstrumentationKey = "<< Instrumentation Key >>"
});
serviceCollection.AddSingleton(x => telemetryClient).AddLogging();

只有跟踪日志记录在应用程序见解中,而记录器对象日志没有出现。 请帮助

1 个答案:

答案 0 :(得分:2)

我通过vs网络作业模板.net Framework 4.6.1创建了一个网络作业项目,步骤如下:

步骤1:创建项目 enter image description here

第2步:安装以下软件包:

Install-Package Microsoft.Azure.WebJobs -version 2.2.0
Install-Package Microsoft.Extensions.Logging -version 2.0.1
Install-Package Microsoft.Extensions.Logging.Console -version 2.0.1
Install-Package Microsoft.Azure.WebJobs.Logging.ApplicationInsights -version 2.2.0
Install-Package System.Configuration.ConfigurationManager -version 4.4.1

第3步:在app.config中,添加以下内容: enter image description here

第4步:我的program.cs:

  using Microsoft.Azure.WebJobs;
  using Microsoft.Extensions.Logging;
  using System.Configuration;

    namespace WebJob7
    {

        class Program
        {

            static void Main()
            {
                var config = new JobHostConfiguration();
                var instrumentationKey =
                   ConfigurationManager.AppSettings["APPINSIGHTS_INSTRUMENTATIONKEY"];

                config.DashboardConnectionString = "";

                config.LoggerFactory = new LoggerFactory()
                    .AddApplicationInsights(instrumentationKey, null)
                    .AddConsole();

                if (config.IsDevelopment)
                {
                    config.UseDevelopmentSettings();
                }

                var host = new JobHost(config);

                host.RunAndBlock();
            }
        }
    }

第5步:我在Function.cs中的代码:

using Microsoft.Azure.WebJobs;
using Microsoft.Extensions.Logging;

namespace WebJob7
{
    public class Functions
    {
        // This function will get triggered/executed when a new message is written 
        // on an Azure Queue called queue.
        public static void ProcessQueueMessage([QueueTrigger("queue")] string message, ILogger logger)
        {
        //you can directly use this line of code.
        //logger.LogError(new Exception(),"it is a test error...");

        //or use the following code
        try
        {
            int i = int.Parse("123er");
        }
        catch(Exception ex)
        {
            logger.LogError(ex,"it's a exception here 0927..........");
        }

        }
    }
}

执行后,日志显示在azure门户中->出现异常: enter image description here

单击以查看详细信息: enter image description here