首页 > 解决方案 > 计划的 .NET WebJob V3 示例

问题描述

我已将我的 .NET(不是 .NET Core)WebJob 从 V2(运行良好)升级到 V3。我无法让它运行。我只是想让 webjob 调用我根据这个 CRON 时间表编写的函数:“0 0 8,10,12,14,16,18,20 * * *”。它运行的网站也是 .NET,而不是 .NET Core。

我该怎么做呢?我只想要一个简单的.NET 代码示例。我已经看到这个问题New Azure WebJob Project - JobHostConfiguration/RunAndBlock missing after NuGet 更新和这个例子https://github.com/Azure/azure-webjobs-sdk/blob/00686a5ae3b31ca1c70b477c1ca828e4aa754340/sample/SampleHost/Program.cs和这个文档https://docs.microsoft.com/en-us/azure/app-service/webjobs-sdk-how-to#triggers但没有任何帮助。

标签: c#asp.netazure-webjobsazure-webjobssdkazure-webjobs-triggered

解决方案


实际上 .Net webjob 或 .Net Core webjob 的使用几乎相同,因为 3.0 sdk 的目标是 .NET 标准 2.0。我用Microsoft.Azure.WebJobs -version 3.0.4and测试Microsoft.Azure.WebJobs.Extensions -version 3.0.1,我认为你的 TimerTrigger 不起作用,因为你失去了调用AddTimers扩展方法。您可以在此处找到描述:绑定类型

我使用的其他包:

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

这是我的main方法:

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

这是我的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}");
    }

并使用appsettings.json(不要忘记设置Copy to Output DirectoryCopy always)来配置存储连接字符串。

结果如下:

在此处输入图像描述


推荐阅读