gpt4 book ai didi

asp.net-mvc - ASP.NET 应用程序和辅助角色之间通信的最佳方式

转载 作者:行者123 更新时间:2023-12-02 07:15:45 24 4
gpt4 key购买 nike

我设置了 ASP.NET 应用程序和辅助角色,现在我想知道如何在它们之间进行通信?我认为这个想法是解决方案将分布在不同的地理位置。那么如何以简单高效的方式链接分布式 Worker 和 Web Roles?我已经开始研究 WCF,但在我看来它太过杀伤力并且过于复杂。我的另一个想法是在 Worker 角色中使用 SignalR 客户端与 Web 角色中的服务器进行通信。

编辑:

确切的上下文:

1)用户上传文件到服务器

2)服务器将文件发送到Azure存储并将文件名添加到CloudQueue

3)Worker从CloudQueue中获取文件名

4)Worker 启动一个新线程,从 Azure 存储获取文件并开始处理

5)Worker/Thread 在文件处理的每一步向应用程序报告

6)应用程序接收报告并使用SignalR将处理步骤实时转发到客户端的浏览器。

我缺少的是步骤2 > 3,如何立即通知工作人员新文件已到达?我不想轮询 CloudQueue,因为它会造成延迟。同样在步骤 5 > 6 中,Worker 需要通知应用程序有关这些步骤的信息,这应该毫不延迟,但我同样不知道在这种情况下如何使用轮询解决方案。

最佳答案

如上所述,需要更多背景信息。您基本上有两个主要选项:Windows Azure 队列和Windows Azure 服务总线队列/主题。我个人的建议是,如果 Web 和辅助角色位于同一区域,则使用 Azure 队列;如果不是,则使用服务总线队列。我不得不问,如果您的应用程序有地理部署,那么您为什么不将 Web 角色和工作角色共置在一起,然后考虑在每个区域部署所有 Web 角色和工作角色,例如美国、欧洲和亚洲,然后使用流量管理器将用户路由到最佳区域。

有一篇很好的博客文章介绍了何时使用哪个队列“Windows Azure 队列和 Windows Azure 服务总线队列 - 比较和对比”:http://msdn.microsoft.com/en-us/library/windowsazure/hh767287.aspx

HTH

编辑

下面是 Web 和 worker 角色通信的一个好方法(我从 @smarx 回答的最近的线程中窃取了这个)

1 Web 角色将一条包含作业 ID 的消息写入队列。

2 辅助角色执行工作并将结果写入带有分区键的表中。

3 Web 角色正在轮询表的该行。一旦存在,答案就会回来。

在您的情况下,您可以让工作角色使用状态更新来更新表存储,然后让您的 Web 角色拾取它们并向用户显示它们。例如20%、50%、完成等...

只要您从网络角色进行充分的轮询(*注意交易成本),我并没有真正看到这种类型的通信延迟

我认为可以在这里进行某种角色间通信以进行状态更新,但在我看来这可能有点过分了:

http://msdn.microsoft.com/en-us/library/windowsazure/hh180158.aspx

关于asp.net-mvc - ASP.NET 应用程序和辅助角色之间通信的最佳方式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12063346/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com