如何在 .Net 核心和任何合适的 azure 资源中处理长时间的处理工作?

问题描述

我在应用程序中工作,它有几个组件,如单页应用程序、用 .Net 核心编写的后端 API 应用程序。我的后端应用程序调用 azure 函数,该函数将根据数据处理运行 2 到 10 分钟。所以我不想等待 Azure 函数完成处理。所以在谷歌搜索了很长一段时间后,我想出了以下方法

我将在我的后端和 azure 函数之间放置一个服务总线/队列。一旦 UI 触发某事,我的后端 API 将被调用并将一些消息添加到队列/服务总线。我将在我的 azure 函数添加一些触发器,以便在将消息添加到服务总线/队列时开始。一旦消息进入队列/服务总线,azure 函数会执行大约 5 分钟,它会再次调用一个 azure 函数,在我的最后一个 azure 函数中,我添加了 SignalR 的实现以将通知推送到 UI。

这就是我认为处理长时间处理作业的解决方案。我所有的 webapps/api 应用程序都部署到 azure 应用程序服务。现在我唯一的问题是这是合适的解决方案还是我可以处理的更好的方法?有人可以帮助我这是最好的解决方案,或者有更好的解决方法

解决方法

由于您已经在使用服务总线,您可能会考虑创建一个工作进程来处理 2 到 10 分钟的处理负载。你有很多选择来编写这种应用程序并在 Azure 中运行它,包括控制台应用程序或函数应用程序。您还可以在您的网络应用中托管长时间播放的服务,权衡是在更复杂的代码(共同托管网络和长时间播放的应用)和部署额外的应用之间进行权衡。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...