我有一个复杂的场景。
我有一个将保存SignalR HUB的Web应用程序。
此应用程序将托管在多台服务器上。
对于前。 Hub1将托管在ServerA和ServerB上。
假设我在ServerA和ServerB上都有很少的客户端。
如果有人在ServerA上广播某些消息,那么ServerB将能够获得该消息 (即使我传递了适当的ConnectionID)?
答案 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