SignalR 分布式部署

发布时间 2023-11-17 10:15:59作者: LiXiang98

分布式部署意味着有多台SignalR服务器,一台服务器有多个客户端连接。

SignalR 要求对于某一个特定连接的所有HTTP 请求都需要被一个相同服务进程处理,当SignalR 运行在一个服务场时(多个服务器),则必须使用“粘性会话”(服务器开启)或者”跳过协商“(用websocket)

问题:某一个客户端给服务器发消息说:“给所有的客户端发一条消息",只会给当前服务器连接的所有的客户端发消息,不会给其他服务器连接的客户端发消息。

官方方案:利用redis进行横向扩展

一、使用asp.net core

  1. 安装nuget包:Microsoft.AstNetCore.SignalR.StackExchangeRedis
  2. 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();
    }
}