当前位置: 首页 > news >正文

ASP.NET Core SignalR的分布式部署

假设聊天室程序被部署在两台服务器上,客户端1、2连接到了服务器A上的ChatRoomHub,客户端3、4连接到服务器B上的ChatRoomHub,那么客户端1发送群聊消息时,只有客户端1、2能够收到,客户端3、4收不到;在客户端3发送群聊消息,只有客户端3、4能够收到,客户端1、2收不到。因为这两台服务器之间的ChatRoomHub没有通信。可以让多台服务器上的集线器连接到一个消息队列中,通过这个消息队列完成跨服务器的消息投递。

微软官方提供了用Redis服务器来解决SignalR部署在分布式环境中数据同步的方案Redis backplane,其使用方法如下

NuGet:Microsoft.AspNetCore.SignalR.StackExchangeRedis

builder.Services.AddSignalR().AddStackExchangeRedis("127.0.0.1", opt =>
{opt.Configuration.ChannelPrefix = "SignalR_MyHub_";
});

AddStackExchangeRedis第一个参数为Redis服务器的连接字符串,如果有多个SignalR应用程序连接同一台Redis服务器,需要为每个应用程序配置唯一的ChannelPrefix

http://www.lryc.cn/news/535702.html

相关文章:

  • Express 中间件
  • ABB能源自动化选用宏集Cogent DataHub避免DCOM问题,实现高效、安全的数据传输
  • springboot239-springboot在线医疗问答平台(源码+论文+PPT+部署讲解等)
  • 【Elasticsearch】分析器的构成
  • Python 调用 Azure OpenAI API
  • 数据结构 算法时间复杂度和空间复杂度
  • CNN-BiGRU卷积神经网络双向门控循环单元多变量多步预测,光伏功率预测
  • 钉钉位置偏移解决,钉钉虚拟定位打卡
  • 【面试集锦】如何设计SSO方案?和OAuth有什么区别?
  • Python 基于 OpenCV 的人脸识别上课考勤系统(附源码,部署教程)
  • vcredist_x64.exe 是 Microsoft Visual C++ Redistributable 的 64 位版本
  • Tailwind CSS 的核心理念
  • 集成学习(二):从理论到实战(附代码)
  • HTML 链接
  • 【机器学习】数据预处理之scikit-learn的Scaler与自定义Scaler类进行数据归一化
  • android的第一个app项目(java版)
  • 上位机知识篇---SSHSCP密钥与密钥对
  • 智慧物流新引擎:ARM架构工控机在自动化生产线中的应用
  • [MySQL]2-MySQL索引
  • DeepSeek冲击下,奥特曼刚刚给出对AGI的「三个观察」,包括成本速降
  • 新数据结构(8)——包装类
  • P5:使用pytorch实现运动鞋识别
  • 讲解下SpringBoot中MySql和MongoDB的配合使用
  • 《手札·行业篇》开源Odoo MES系统与SKF Observer Phoenix API在化工行业的双向对接方案
  • 数据结构与算法之数组: LeetCode 905. 按奇偶排序数组 (Ts版)
  • 【STM32】HAL库Host MSC读写外部U盘及FatFS文件系统的USB Disk模式
  • docker nginx 配置文件详解
  • 如何实现华为云+deepseek?
  • 【学习笔记】计算机网络(三)
  • 稀土抑烟剂——为汽车火灾安全增添防线