问题描述
我在应用程序中工作,它有几个组件,如单页应用程序、用 .Net 核心编写的后端 API 应用程序。我的后端应用程序调用 azure 函数,该函数将根据数据处理运行 2 到 10 分钟。所以我不想等待 Azure 函数完成处理。所以在谷歌搜索了很长一段时间后,我想出了以下方法。
我将在我的后端和 azure 函数之间放置一个服务总线/队列。一旦 UI 触发某事,我的后端 API 将被调用并将一些消息添加到队列/服务总线。我将在我的 azure 函数中添加一些触发器,以便在将消息添加到服务总线/队列时开始。一旦消息进入队列/服务总线,azure 函数会执行大约 5 分钟,它会再次调用另一个 azure 函数,在我的最后一个 azure 函数中,我添加了 SignalR 的实现以将通知推送到 UI。
这就是我认为处理长时间处理作业的解决方案。我所有的 webapps/api 应用程序都部署到 azure 应用程序服务。现在我唯一的问题是这是合适的解决方案还是我可以处理的更好的方法?有人可以帮助我这是最好的解决方案,或者有更好的解决方法。
解决方法
由于您已经在使用服务总线,您可能会考虑创建一个工作进程来处理 2 到 10 分钟的处理负载。你有很多选择来编写这种应用程序并在 Azure 中运行它,包括控制台应用程序或函数应用程序。您还可以在您的网络应用中托管长时间播放的服务,权衡是在更复杂的代码(共同托管网络和长时间播放的应用)和部署额外的应用之间进行权衡。