Scheduled .NET WebJob V3 example

后端 未结 2 818
陌清茗
陌清茗 2021-01-15 00:11

I\'ve upgraded my .NET (not .NET Core) WebJob from V2 (which was working fine) to V3. I\'m having trouble getting it to run. I just want the webjob to call a function I\'ve

2条回答
  •  执念已碎
    2021-01-15 01:00

    Actually the use of .Net webjob or .Net Core webjob are almost same, cause the 3.0 sdk targets .NET standard 2.0. I test with Microsoft.Azure.WebJobs -version 3.0.4 and Microsoft.Azure.WebJobs.Extensions -version 3.0.1, i think your TimerTrigger doesn't work cause you lost call the AddTimers extension methods. You could find the description here:Binding types.

    Other package I use:

    Microsoft.Extensions.Logging -version 2.2.0
    Microsoft.Extensions.Logging.Console -version 2.2.0
    

    This is my main method:

    using Microsoft.Extensions.Logging;
    using Microsoft.Extensions.Hosting;
    namespace ConsoleApp20
    {
    class Program
    {
        static void Main(string[] args)
        {
            var builder = new HostBuilder();
            builder.ConfigureWebJobs(b =>
            {
                b.AddAzureStorageCoreServices();
                b.AddTimers();
            });
            builder.ConfigureLogging((context, b) =>
            {
                b.AddConsole();
    
            });
            var host = builder.Build();
            using (host)
            {
                host.Run();
            }
        }
    }
    }
    

    This is my Functions.cs:

    public static void Run([TimerTrigger("0 0 8,10,12,14,16,18,20 * * *")]TimerInfo myTimer, ILogger log)
        {
    
            log.LogInformation($"C# Timer trigger function executed at: {DateTime.Now}");
        }
    

    And use a appsettings.json(Don't forget set the Copy to Output Directory to Copy always) to configure the storage connection string.

    Here is the result:

提交回复
热议问题