zoukankan      html  css  js  c++  java
  • signalR 在webfarm下的配置

    建立一个站点(server),提供signalR服务

    建立另一个站点(client),调用signalR服务

    把server配置到web farm下

    client通过webfarm调用。

    webfarm不支持websocket,所以退化成长连接(据说nginx好像支持了,没试过)。

    当farm下只有一个节点时,一切正常,当加入2个节点后

    在调用/signalr/connect或/signalr/reconnect时,有时会报错

    The connection id is in the incorrect format.

    这个与connection id和connection token的生成验证有关。

    于此相关的接口为IProtectedData

    实现此接口(源码中有测试部分,可参考)不做乱七八糟的验证,直接返回

    public class EmptyProtectedData : IProtectedData
    {
        public string Protect(string data, string purpose)
        {
            return data;
        }
    
        public string Unprotect(string protectedValue, string purpose)
        {
            return protectedValue;
        }
    }

    最后注册到依赖注入中。注意注册的位置

    RouteTable.Routes.MapHubs(new Microsoft.AspNet.SignalR.HubConfiguration { EnableCrossDomain = true, EnableJavaScriptProxies = true });
    GlobalHost.DependencyResolver.Register(typeof(IProtectedData), () => new EmptyProtectedData());

    要在MapHubs后面。否则是不起作用的。

    因为加入了负载,是两台以上的真实服务器,监听连接到A,而发送负载到B,此时要B的发送引起A的监听返回。单纯上面的配置是不行的。

    还需要引入对负载的支持。

    目前提供了基于azure,redis和sql server的,实验环境用的是sql server。配置很简单可参考http://www.asp.net/signalr/overview/performance-and-scaling/scaleout-with-sql-server

    本实验,client和server用的是不同的站点,及2个域名,所以还要开启跨域支持

    RouteTable.Routes.MapHubs(new Microsoft.AspNet.SignalR.HubConfiguration { EnableCrossDomain = true, EnableJavaScriptProxies = true });
  • 相关阅读:
    vue 按需加载
    需要打印真实尺寸大小等需求的,css的单位可以使用mm等做单位
    d3 比例尺
    d3 根据数据绘制svg
    d3 svg简单学习
    d3 使用随机数据生成条形图
    d3 画简单的柱形图
    d3 使用数据
    d3 数据绑定
    d3 添加元素相关api
  • 原文地址:https://www.cnblogs.com/czcz1024/p/3134136.html
Copyright © 2011-2022 走看看