分布式部署意味着有多台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(); } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 一文读懂知识蒸馏
· 终于写完轮子一部分:tcp代理 了,记录一下