分布式部署意味着有多台SignalR服务器,一台服务器有多个客户端连接。
SignalR 要求对于某一个特定连接的所有HTTP 请求都需要被一个相同服务进程处理,当SignalR 运行在一个服务场时(多个服务器),则必须使用“粘性会话”(服务器开启)或者”跳过协商“(用websocket)
问题:某一个客户端给服务器发消息说:“给所有的客户端发一条消息",只会给当前服务器连接的所有的客户端发消息,不会给其他服务器连接的客户端发消息。
官方方案:利用redis进行横向扩展
一、使用asp.net core
- 安装nuget包:Microsoft.AstNetCore.SignalR.StackExchangeRedis
- builder.Services.AddSignalR().AddStackExchangeRedis("127.0.0.1",options= options.Configuration.ChannelPrefix="Test_";})
二、使用asp.net
1、安装nuget包:Install-Package Microsoft.AspNet.SignalR.StackExchangeRedis
2、在StartUp.cs中添加代码
public class Startup { public void Configuration(IAppBuilder app) { // Any connection or hub wire up and configuration should go here GlobalHost.DependencyResolver.UseStackExchangeRedis("server", port, "password", "AppName"); app.MapSignalR(); } }
标签:部署,连接,SignalR,服务器,分布式,发消息,客户端 From: https://www.cnblogs.com/lixiang1998/p/17838043.html