3

我已经实现了一个 websocket 服务器作为 WebRole.cs 的一部分,到目前为止它可以工作,用户可以使用网站的 URL 和指定的端点连接到服务器。现在假设我有 50,000 个用户想要连接到 websocket 服务器,我将需要更多该 web 角色的实例来处理负载。

我的问题是,如果有多个 Web 角色实例,这是否也会导致多个 Web 套接字服务器?即用户是否仍然只使用一个 URL/IP 进行连接并且都相互连接(例如在广播消息时),或者用户是否需要输入不同的 IP 才能连接到不同的 websocket 服务器(每个实例一个)并且只连接到同一服务器/实例上的用户?

编辑:具体问题

因此,如果在连接时将用户添加到:

private static List<UserContext> Users = new List<UserContext>();

在 WebRole.cs 中。我有一个广播方法:

private static void Broadcast(String message)
        {
            foreach (UserContext uc in Users)
            {
                uc.Send(message);
                Console.WriteLine("Broadcasting to: " + Users.IndexOf(uc));
            }
        }

消息会广播给网站上的所有用户,还是每个实例都有自己的用户列表,因此只广播给连接到特定实例的用户?

4

2 回答 2

4

虽然 Simon 关于负载均衡器将处理所有请求这一事实是正确的(您无需担心需要连接到哪个实例),但您还需要考虑其他一些事情。从您的问题中,我了解到您想要广播消息。

假设您将应用程序扩展到 2 个实例:

  • 实例 1
  • 实例 2

负载均衡器将确保对yourapp.cloudapp.net的所有请求都转到这些实例之一(循环)。现在假设用户 A、B 和 C 被路由到实例 1,用户 D、E 和 F 被路由到实例 2:

  • 实例1:用户A、用户B、用户C
  • 实例2:用户D、用户E、用户F

所以让我们假设用户 A 在你的应用程序中做了一些事情,并且你想将它广播给你的所有用户。实例 1 只会看到 2 个其他已连接的用户:用户 B 和 C,并将向这些用户发送消息。这里的问题是您还想将消息发送给用户 D、E 和 F,即使它们位于不同的实例上。

这就是为什么您的 WebSocket/broadcast/... 框架(如 SignalR)需要使用可从所有实例访问的服务总线之类的东西。看看 SignalR 如何使用Windows Azure 服务总线redis解决这个问题。

于 2013-02-27T11:38:50.110 回答
3

您要连接的网站 URL 实际上是负载均衡器的 URL,而不是特定实例(与公共 IP 相同,它是负载均衡器中的虚拟 IP)。当您添加更多实例时,负载均衡器会将流量定向到底层实例(通过循环)。除了公共 URL 和 IP 地址之外,您永远不必担心其他任何事情(虚拟网络除外,其中不使用负载平衡器)。

Alchemy UserContext 具有端点客户端地址。单个服务器将只有连接到它的用户的源地址,而不是其他服务器。您必须从两台服务器进行广播。因此,如果您在所有服务器上广播(),您将捕获所有用户。小心重复。由于 NLB 不执行粘性会话,因此单个用户可能会存在于多个服务器上。确保您的客户端代码可以处理来自多个服务器的相同消息

于 2013-02-27T09:11:56.950 回答