我有一个复杂的场景.
我有一个Web应用程序将保存SignalR HUB.
此应用程序将托管在多个服务器上.
对于前者 Hub1将托管在ServerA和ServerB上.
假设我在ServerA和ServerB上都有很少的客户端.
如果有人在ServerA上广播某些消息,那么ServerB将能够获得该消息(即使我传递了适当的ConnectionID)?
我想在SignalR 2.0中你可以看看Introduction to Scaleout in SignalR
.
我没有对它进行过测试,但是文档报告说,例如Microsoft.AspNet.SignalR.SqlServer
,您将使用SQL Server处理负载平衡.
参考:http://www.asp.net/signalr/overview/signalr-20/performance-and-scaling/scaleout-in-signalr
是的,但你需要使用背板.有一些受支持的,例如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