c# - Azure WebJobs SDK TimerTrigger 函数未运行
问题描述
我正在尝试创建一个每 x 秒运行一次函数的 Azure WebJob。我正在关注Microsoft 网站上的教程以及如何在Github上将 TimerTrigger 与 WebJobs 一起使用的示例。但是,当我在本地运行时,我在 Functions.cs 中的方法似乎没有运行(没有日志记录和断点未命中)。
程序.cs:
public class Program
{
static async Task Main()
{
var builder = new HostBuilder();
builder.ConfigureWebJobs(b =>
{
b.AddAzureStorageCoreServices();
});
var host = builder.Build();
using (host)
{
await host.RunAsync();
}
}
}
函数.cs:
public class Functions
{
public static void TimerJob([TimerTrigger("00:00:03", RunOnStartup = true)] TimerInfo timer)
{
Console.WriteLine("Timer job fired!");
}
}
我在调试控制台中的唯一输出是:
Hosting environment: Production
Content root path: C:\Users\<blah>\<Project\bin\Debug\net472\
这是我的 nuget 包和版本:
我正在使用 .NET Framework 4.7.2
解决方案
最后,我弄清楚了为什么我们的定时触发器没有在我们的 webjob 中触发。安装以下内容后,nuget packages,
我能够在我的.net framework 4.7.1function.cs
中使用您的代码使其工作。
因此,为了使我们的带有计时器触发器的 webjob 工作,我们需要使用带有以下包的 2.X 或 3.X 版本:
Microsoft.Azure.WebJobs.Extensions -版本 3.0.6
Microsoft.Azure.WebJobs.Extensions.Storage -版本 3.0.1
Microsoft.Extensions.Logging -版本 2.1.0
Microsoft.Extensions.Logging.Console -版本 2.1.0
作为参考检查我在我的环境中使用的所有包:
<?xml version="1.0" encoding="utf-8"?>
<packages>
<package id="Microsoft.Azure.KeyVault.Core" version="1.0.0" targetFramework="net472" />
<package id="Microsoft.Azure.WebJobs" version="3.0.14" targetFramework="net472" />
<package id="Microsoft.Azure.WebJobs.Core" version="3.0.14" targetFramework="net472" />
<package id="Microsoft.Azure.WebJobs.Extensions" version="3.0.6" targetFramework="net472" />
<package id="Microsoft.Azure.WebJobs.Extensions.Storage" version="3.0.1" targetFramework="net472" />
<package id="Microsoft.Azure.WebJobs.Host.Storage" version="3.0.14" targetFramework="net472" />
<package id="Microsoft.Extensions.Configuration" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.Configuration.Abstractions" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.Configuration.Binder" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.Configuration.EnvironmentVariables" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.Configuration.FileExtensions" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.Configuration.Json" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.DependencyInjection" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.DependencyInjection.Abstractions" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.FileProviders.Abstractions" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.FileProviders.Physical" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.FileSystemGlobbing" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.Hosting" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.Hosting.Abstractions" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.Logging" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.Logging.Abstractions" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.Logging.Configuration" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.Logging.Console" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.Options" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.Options.ConfigurationExtensions" version="2.1.0" targetFramework="net472" />
<package id="Microsoft.Extensions.Primitives" version="2.1.0" targetFramework="net472" />
<package id="ncrontab.signed" version="3.3.0" targetFramework="net472" />
<package id="Newtonsoft.Json" version="11.0.2" targetFramework="net472" />
<package id="System.Buffers" version="4.4.0" targetFramework="net472" />
<package id="System.ComponentModel.Annotations" version="4.4.0" targetFramework="net472" />
<package id="System.Diagnostics.TraceSource" version="4.3.0" targetFramework="net472" />
<package id="System.Memory" version="4.5.0" targetFramework="net472" />
<package id="System.Numerics.Vectors" version="4.4.0" targetFramework="net472" />
<package id="System.Runtime.CompilerServices.Unsafe" version="4.5.0" targetFramework="net472" />
<package id="System.Threading.Tasks.Dataflow" version="4.8.0" targetFramework="net472" />
<package id="WindowsAzure.Storage" version="9.3.1" targetFramework="net472" />
这是我 刚刚Program.cs
添加 AddTimers
扩展方法 的地方b.AddAzureStorageCoreServices();
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Hosting;
namespace usetimertrigger
{
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();
}
}
}
}
function.cs
using Microsoft.Azure.WebJobs;
using Microsoft.Extensions.Logging;
using System;
namespace usetimertrigger
{
public class Functions
{
public static void TimerJob([TimerTrigger("00:00:03", RunOnStartup = true)] TimerInfo timer)
{
Console.WriteLine("Ajay timer trigger fired!");
}
}
}
如MS DOC中所述,添加了从 Azure 门户>存储帐户>访问密钥复制的存储帐户访问密钥
并且appsettings.json
应该始终复制到输出目录以复制以配置我们的存储连接字符串,如下所示。
输出:-
添加前b.AddTimers();
添加后b.AddTimers();
参考:
SO THREAD:计划的 .NET WebJob V3 示例
推荐阅读
- python - 从 HTML 中提取脚本标签中的字符串
- python - Python_如何计数
- php - PHP-MySQL-SSH:如何在使用 SSH 隧道(托管在 CentOS 上)时从 PHP 连接到 mysql 数据库
- c# - C# 查找同一层次结构的两种类型共享的属性
- javascript - ReactJS – TextArea onChange 仅在 iPhone 上不触发
- node.js - 从 URL 获取 blob 并写入文件
- sql-server - (Sparx) 共享 SQL Server 存储库导致数据库锁定
- flutter - 对 Flutter 的 CallKit 支持
- javascript - 使用 JavaScript 或 Angular CLI 将视频文件作为 blob 上传到 AWS S3
- android - 用 GSON 解析 JSON?