如果SignalR集线器托管在多个服务器上怎么办?

时间:2014-03-19 10:25:06

标签: signalr signalr-hub

我有一个复杂的场景。

我有一个将保存SignalR HUB的Web应用程序。

此应用程序将托管在多台服务器上。

对于前。 Hub1将托管在ServerA和ServerB上。

假设我在ServerA和ServerB上都有很少的客户端。

如果有人在ServerA上广播某些消息,那么ServerB将能够获得该消息 (即使我传递了适当的ConnectionID)?

2 个答案:

答案 0 :(得分:7)

我认为在SignalR 2.0中你可以看一下Introduction to Scaleout in SignalR

我还没有测试过,但是文档报告说例如Microsoft.AspNet.SignalR.SqlServer将使用SQL服务器为您处理负载平衡。

参考:http://www.asp.net/signalr/overview/signalr-20/performance-and-scaling/scaleout-in-signalr

答案 1 :(得分:5)

是的,但您需要使用背板。有一些受支持的,例如Redis或SQL。

我使用了SQL背板,它使用了一个表和一个BLOB数据列,可以在SignalR的所有实例之间同步任何用户/组/集线器/消息。在application_start上,您只需添加一行代码即可使用SQL背板,并在幕后为您处理。

如果表现非常令人担忧,请使用Redis。如果您想要简单和易于配置,请使用SQL。

http://www.asp.net/signalr/overview/signalr-20/performance-and-scaling/scaleout-with-sql-server