- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
目前我正在使用 asp.net 开发一个 WebApi 项目。我想将所有非时间关键且长时间运行的操作转移到 webjobs 中,以保持我的 API 快速而简单。
例如,当创建特定资源时,它会立即创建(实体状态:已创建/配置),并且新的队列消息将入队。现在,Web 作业接收队列上的消息并开始配置任务。作业成功/失败后,资源/实体将被更新(状态:已完成/失败)。
没什么特别的。但现在我还想将具体化统计数据、报告等部分转移到目前即时计算的作业中。
当我将所有这些时间不重要的任务移动到单独队列中的网络作业中时,例如:
配置队列更新统计A创建报表B...
同时拥有这么多队列(20-50)是一种不好的做法吗(它们都会一直被轮询/检查)。为了清楚起见:每条消息一个队列。遗憾的是,我没有找到任何方法/示例如何创建多个作业函数来监听同一队列但具有不同的消息。另外,我没有发现使用多个队列有什么好处/坏处。仅具有 1-3 个工作功能的示例(图像转换、调整大小......)。
Azure 服务总线听起来也不错(因为有主题)。我不确定我使用网络作业和存储队列的方式是否正确或好。我想要的只是将许多非时间关键且长时间运行的任务与 webapi 解耦。
谢谢大家!
最佳答案
使用多个队列完全没有问题,每个队列都有一个需要处理的单独消息类型。
有两种方法可以处理来自这些队列的消息:将所有队列监控方法放入单个 Web 作业中,或者将每个队列的监控器拆分到其自己的单独 Web 作业中。我个人喜欢将队列监视器拆分为单独的 Web 作业,因为它使您能够根据需要将 Web 作业移动到单独的 Web 应用程序。例如,假设您有 WebJobs A、B 和 C 正在监视队列 A、B 和 C。如果 A 的工作负载始终很重,而 B 和 C 的负载始终很轻,您可以将 A 移动到单独的 Web应用程序位于不同的应用程序服务计划上,B 和 C 可以共享一个 Web 应用程序。这是一种微服务方法。
主题在这种情况下没有用处。
服务总线是一个好方法,您需要保证至少一次和最多一次交付。此外,您还可以轻松拥有一个保存不同消息类型的服务总线队列(如果您想采用这种方式)。您可以通过 BrokeredMessage 类实例在服务总线中发送消息。您可以为每种消息类型创建一个 BaseMessage 类、BaseMessage 子类,通过序列化为 JSON(或您想要使用的任何格式)通过 BrokeredMessage 打包消息,然后测试以查看出队操作期间您拥有的子类。
关于.net - Azure WebJobs 有很多 QueueTrigger 不好的做法吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43453520/
我有一个 Azure WebJob,我正在从 visual studio 2017 发布到标准 S1 应用服务,WebJob 应该由 CRON 触发,但始终发布为连续,我无法弄清楚我做错了什么(另外两
我需要在计划的时间段内为不同的用户运行一项作业(例如 CRM 同步)。此同步由 ServiceBus 队列上的另一个函数放置的消息触发,该函数每 30 分钟由 TimerTrigger 触发一次。 现
我需要在计划的时间段内为不同的用户运行一项作业(例如 CRM 同步)。此同步由 ServiceBus 队列上的另一个函数放置的消息触发,该函数每 30 分钟由 TimerTrigger 触发一次。 现
我无法将计划的 Web 作业发布到 Azure 应用服务。我正在使用 Visual Studio 2017。 使用此设置一切正常: { "$schema": "http://schemastore.o
我计划使用连续的 Azure WebJob 发送电子邮件和推送通知。我了解 WebJobs 会因各种原因不时启动和停止。没关系,但我希望有机会在工作关闭之前“清理”一下。 这样我的 WebJob 可以
我已经看到了一些关于使用 settings.job 的指导。为此,但它不起作用 - 在控制台中我看到: WebJob singleton setting is False 如何防止横向扩展运行我的
我正在尝试部署一个触发的网络作业并使用 settings.json 文件安排它。我的 webapp 在 3 个实例中运行,所以我假设 webjob 将在 3 个实例中部署。因此,如果我使用带有 cro
我正在尝试找出是否有任何方法可以修改 webjobs sdk 重试策略。 现在,如果网络作业抛出异常,它会立即重新排队。这并不理想,特别是如果错误是由于数据库超时之类的原因造成的。 有谁知道该策略是否
我正在尝试部署一个触发的网络作业并使用 settings.json 文件安排它。我的 webapp 在 3 个实例中运行,所以我假设 webjob 将在 3 个实例中部署。因此,如果我使用带有 cro
我有一个启用了 Azure 持续交付的 Web 应用程序 (azure webapp)。这意味着每当我进行提交并将其推送到远程时,它都会自动构建应用程序并部署它。 我还有一些网络作业,我希望该过程也可
有没有办法从 MVC 应用程序中更改 webjob 的预定时间,或者是通过 azure 门户的唯一方法。 我不是指初始计划时间,而是在部署后通过 Mvc 应用程序中的 UI 更改计划时间。 最佳答案
Azure 提供了创建“触发式”WebJob 的可能性,例如每天都有时间表。 此外,还有 azure-webjobs-sdk-extensions( https://github.com/Azure/
我开始使用 WebJobs 来处理一些后台任务,但我遇到了关于错误处理和重试的问题。看来,如果我的任何函数是异步的,那么即使我在函数中抛出异常,该函数总是会在仪表板中报告成功。 考虑以下简单示例 ->
我们有一个带有“暂存”部署槽的 Azure 网站设置,我们使用连续的 Azure WebJob 来处理长时间运行的后台作业。看来,当您发布到网站(并包含 WebJob 二进制文件)时,如果 WebJo
我正在开发一个使用 TimerTrigger 的触发式网络作业. 在webjob停止之前,我需要处理一些对象,但我不知道如何触发“webjob停止”。 有了 NoAutomaticTrigger 函数
我正在处理一个网络作业,用于检查网络服务器的一些数据。有时网络服务器很忙,会在几秒钟后重试。 问题是,如果我只是忽略它并通过该函数,它将从队列中删除消息,我将无法重试调用。 我当前的解决方案(我一点也
我读过关于优雅关机的文章 here使用 WEBJOBS_SHUTDOWN_FILE 和 here使用取消 token ,所以我理解正常关闭的前提,但是我不确定它们将如何影响正在处理队列消息的 WebJ
如果运行webjob时出现任何异常或错误,我想释放所有对象。我如何知道是否发生错误。webjob 是否有任何错误触发器? 最佳答案 可以有两种方法来处理这个问题: 1) Try/Catch 方法:-
我在 AppService 中长时间运行 Web 作业(大约 1 小时)。AppService 已打开“始终打开”。 它的初始化是: var host = new JobHost(config); h
我在 AppService 中长时间运行 Web 作业(大约 1 小时)。AppService 已打开“始终打开”。 它的初始化是: var host = new JobHost(config); h
我是一名优秀的程序员,十分优秀!