多个应用程序池上的 SignalR

SignalR on multiple application pools

我正在尝试从服务器向特定客户端发送有关事务更改的通知。到目前为止,我在本地和开发环境中表现良好,但在 LIVE 中,我们有 3 个带有负载均衡器的应用程序池(3 个物理服务器)(所有三个都具有相同的机器密钥)。

所以看起来当客户端连接到同一个池上的服务器端时触发通知 - 它有效,但如果池不同则不起作用。

任何人都可以建议如何处理这个 - 或者问题可能出在错误的代码中(不正确的集线器上下文处理或其他)。我是 SignalR 的新手 - 所以使用了来自 SignalR 文档的消息广播示例。

这里是 mu hub:

public class ExampleClassHub : Hub
{
    private readonly ExampleClass _ExampleClassInstance;
    public ExampleClassHub() : this(ExampleClass.Instance) { }

    public ExampleClassHub(ExampleClass ExampleClassInstance)
    {
        _ExampleClassInstance = ExampleClassInstance;
    }
}

这是服务于静态实例的 class:

public class ExampleClass
{
    private readonly static Lazy<ExampleClass> _instance = new Lazy<ExampleClass>(() =>
        new ExampleClass(GlobalHost.ConnectionManager.GetHubContext<ExampleClassHub>().Clients));

    private IHubConnectionContext<dynamic> Clients { get; set; }

    private ExampleClass(IHubConnectionContext<dynamic> clients)
    {
        Clients = clients;
    }

    public static ExampleClass Instance
    {
        get
        {
            return _instance.Value;
        }
    }

    public void NotifyTransactionChange(int userId, string tid, bool isTransactionSuccessfull)
    {
        string json = JsonConvert.SerializeObject(new Notification { UserId = userId, Tid = tid, IsTransactionSuccessful = isTransactionSuccessfull });
        Clients.User(userId.ToString()).notifyTransactionStateChange(json);
    }


    class Notification
    {
        public int UserId { get; set; }
        public string Tid { get; set; }
        public bool IsTransactionSuccessful { get; set; }
    }
}

因此服务器端通知是通过以下方式触发的:

ExampleClass.Instance.NotifyTransactionChange(...)

使用 SignalR scaleout 解决: http://www.asp.net/signalr/overview/performance/scaleout-in-signalr