7

假设我有一个带有一个真实网络接口和几个环回接口的 Windows 7。我有启用 IOCP 的服务器,它接受来自客户端的连接。我正在尝试尽可能多地模拟与服务器的真实客户端连接。

我的客户端代码只是建立了 X 数量的套接字连接(请注意,客户端绑定到给定的接口):

        const Int32 remotePort = 12345;
        const Int32 MaxSockets = 60000;

        Socket[] s = new Socket[MaxSockets];
        IPEndPoint bindEndpoint = new IPEndPoint(IPAddress.Parse(args[0]), 0);
        for (Int32 i = 0; i < MaxSockets; i++)
        {
            s[i] = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
            s[i].SetSocketOption(SocketOptionLevel.Socket, SocketOptionName.ReuseAddress, true);
            s[i].Bind(bindEndpoint);
            s[i].Connect(args[1], remotePort);

            IPEndPoint socketInfo = (IPEndPoint)s[i].LocalEndPoint;
            Console.WriteLine(String.Format("Connected socket {0} {1} : {2}", i, socketInfo.Address, socketInfo.Port));
        }

在环回接口上,我有几个用于绑定的 IP。另外,我也用真实的接口来绑定。当每台机器打开的套接字数量约为 64K 时,我遇到了一个问题:

未处理的异常:System.Net.Sockets.SocketException:无法对套接字执行操作,因为系统缺少足够的缓冲区空间或队列已满

我尝试了一些无助的事情,例如: - 在注册表中将 MaxUserPort 设置为最大值和其他一些推荐的 TCPIP 设置。- 尝试在不同的接口(真实接口和环回)上运行两台服务器并使用多个客户端。

它是 Windows 中的一个已知限制还是有可能以某种方式克服它?

谢谢您的帮助!

4

4 回答 4

5

我在一些微软页面上发现:

... HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\MaxUserPort 注册表子项被定义为最大端口,最多可以为通配符绑定分配端口。MaxUserPort注册表项的值定义了动态端口范围...

所以,如果我强制端点使用某个端口,例如

IPEndPoint bindEndpoint = new IPEndPoint(IPAddress.Parse(args[0]), 54321);

然后我可以在系统中同时打开超过 64K 个套接字。

于 2012-02-29T19:33:11.617 回答
1

在您的代码示例中,您正在调用Bind(bindEndpoint),但没有显示如何bindEndpoint定义。检查:

  • 您的系统实际上有多个 IP 地址(环回不计算在内)
  • 您实际上是将端点的 IP 地址设置为 IP 地址(不是环回)
  • 绑定分布在多个 IP 地址上

环回地址不计算在内,因为许多系统将其专门用于路由和绑定目的。因此,在环回中绑定到端口可能会占用所有地址的端口,就像您绑定到INADDR_ANY( 0.0.0.0) 一样。

于 2012-02-29T16:59:03.603 回答
0

TCP 和 UDP 都使用无符号的 16 位整数来指定端口号。我不认为任何操作系统中的任何实现最多能够为每个绑定地址打开超过 65535 个套接字。此外,如果 Windows 没有为每个适配器或每个绑定地址实现完全隔离的状态表,而是依赖于全局状态表,我也不会感到惊讶。如果是这种情况,这将是一个 Windows 网络架构限制,而不是一个可配置的软限制。

于 2016-06-28T16:14:54.627 回答
0

我开发了一个负载测试工具。

在 Windows 10/16G RAM 上运行,它可以成功创建 60,000 个与服务器的连接。

但是当尝试创建更多连接时,该工具很快会报告“socket WinError 10055 No Buffer Space Available”。

根据这篇文章,我认为限制是整个操作系统的整体套接字缓冲区大小,而不是打开文件的数量。

于 2020-07-07T08:02:31.797 回答