人为地创建连接超时错误

我在我们的软件中有一个错误,当我收到连接超时时发生。这些错误是非常罕见的(通常是当我的连接被我们的内部网络丢弃时)。我怎样才能人为地产生这种效果来测试我们的软件呢?

如果重要,应用程序是用c++ /MFC编写的,使用CAsyncSocket类。

编辑:

我尝试使用一个不存在的主机,我得到套接字错误:

无效的参数

我的下一个尝试是使用亚历山大的建议连接到不同的端口,例如81(在我自己的服务器上)。这很有效。与断开连接完全相同(等待60秒,然后出错)。谢谢你!

194033 次浏览

把你的网线插到没有其他连接/电缆的交换机上。恕我直言,这应该有用。

连接到一个现有的主机,但是连接到一个被防火墙阻塞的端口,防火墙只是丢弃TCP SYN包。例如:www.google.com:81。

我过去曾使用过一些策略来模拟网络问题;

  1. 拔出网线
  2. 关闭你的机器和“目标”机器之间的开关(理想情况下,计算机插入的开关仍在供电,以便机器保持“网络连接”)
  3. 在目标计算机上运行防火墙软件,以静默方式丢弃接收到的数据

其中一个想法可能会为您提供一些人为生成所需场景的方法

取决于你已经安装/可用的防火墙软件,你应该能够阻止传出端口,这取决于你的防火墙是如何设置的,它应该只是丢弃连接请求包。没有连接请求,没有连接,超时。如果它是在路由器级别上实现的,这可能会工作得更好(他们倾向于丢弃数据包而不是发送重置,或任何等价的情况),但一定会有一个软件包也能做到这一点。

我和你有同样的问题。为了测试软件的行为,我只是在适当的时候拔掉了网线。在我想拔掉电缆之前,我必须设置一个断点。

如果让我再做一次,我会在网线上放一个开关(一个正常关闭的瞬间按钮)。

如果物理断开导致不同的行为,您可以将您的计算机连接到一个便宜的集线器,并在集线器和主网络之间放置我上面提到的开关。

——编辑—— 在许多情况下,你需要网络连接工作,直到你到达程序中的某个点,然后你会想要使用提供的许多建议之一断开连接

您可以尝试在外部端口(例如200)上连接到一个知名的Web站点。大多数防火墙都在DROP模式下工作,它会为你模拟超时。

最简单的方法是使用CurrPorts删除连接。

然而,为了单元测试你的异常处理代码,也许你应该考虑抽象你的网络连接代码,并编写一个存根、mock或decorator来按需抛出异常。然后,您将能够测试应用程序错误处理逻辑,而不必实际使用网络。

您可以安装Microsoft Loopback驱动程序,它将为您创建一个单独的接口。然后,您可以在它上连接到您的某些服务(您自己的主机)。然后在网络连接中,你可以禁用/启用这样的接口…

尽管还不完全清楚OP想要测试哪一个:尝试连接到不存在的主机/端口和超时已经建立的连接之间是有区别的。我会和罗布一起去,等连接好了再拉电缆。或者——为了方便起见——让虚拟机作为测试服务器(使用桥接网络),一旦建立连接,就取消激活虚拟网络接口。

请连接不可路由的IP地址,如10.255.255.1。

软件解决方案怎么样:

在应用服务器上安装SSH服务器。然后,使用套接字隧道在您的本地端口和应用服务器上的远程端口之间创建一条链路。您可以使用ssh客户端工具来实现这一点。让您的客户端应用程序连接到映射的本地端口。然后,您可以随意打破套接字隧道来模拟连接超时。

您可以使用Python REPL来模拟接收数据时的超时(即在连接成功建立之后)。只需要一个标准的Python安装。

Python 2.7.4 (default, Apr  6 2013, 19:54:46) [MSC v.1500 32 bit (Intel)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> import socket
>>> s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
>>> s.bind(('localhost', 9000))
>>> s.listen(0)
>>> (clientsocket, address) = s.accept()

现在它等待一个传入连接。将你想要测试的任何东西连接到localhost:9000。当你这样做时,Python将接受连接,accept()将返回它。除非你通过clientsocket发送任何数据,否则调用者的套接字应该在下一个recv()期间超时。

我想提醒大家注意mitmproxy

使用200:b@100:dr的配置(取自他们的例子),你会得到一个随机断开的连接。

  • 10.0.0.0
  • 10.255.255.255
  • 172.16.0.0
  • 172.31.255.255
  • 192.168.0.0到
  • 192.168.255.255

所有这些都是不可路由的。

如果你在unix机器上,你可以使用netcat启动一个端口监听:

nc -l 8099

然后,修改你的服务来调用它通常对该端口所做的事情,例如http://localhost:8099/some/sort/of/endpoint

然后,您的服务将打开连接并写入数据,但永远不会得到响应,因此将给您一个“读取超时”(而不是“拒绝连接”)。

对我来说,最简单的方法是根据目的网络在办公路由器上添加静态路由。只是将流量路由到一些没有响应的主机(例如您的计算机),您将得到请求超时。

对我来说最好的事情是静态路由可以通过web界面管理,并且很容易启用/禁用。

如果你想使用一个活动连接,你也可以使用http://httpbin.org/delay/#,其中#是你希望他们的服务器在发送响应之前等待的时间。只要你的超时时间比延迟时间短……应该是模拟效果。我已经成功地将它与python请求包一起使用。

如果你要发送任何敏感的东西,你可能需要修改你的请求——不知道发送给他们的数据会发生什么。

有一些可用的服务允许您通过调用API(在其中指定服务器响应所需的时间)来人为地创建原始超时。macgyver上的Server Timeout就是这样一个服务的例子。

例如,如果您想测试一个需要15秒响应的请求,您只需向macgyver API发送一个post请求。

JSON载荷:

{
"timeout_length": 15000
}

API响应(15秒后):

{
"response": "ok"
}

服务器超时程序在macgyver上
https://askmacgyver.com/explore/program/server-timeout/3U4s6g6u < / p >

下面的URL总是给出一个超时,并结合了@Alexander和@Emu上面最好的答案:

http://example.com:81

使用example.com:81是对Alexander的答案的改进,因为example.com是由DNS标准保留的,因此它将始终不可访问,不像google.com:81,如果谷歌感觉像它,它可能会改变。此外,因为example.com被定义为不可达,所以你不会淹没谷歌的服务器。

我想说这比@emu的答案有进步,因为它更容易记住。

我经常用来模拟随机连接超时的技术是使用ssh本地端口转发。

ssh -L 12345:realserver.com:80 localhost
这将把localhost:12345上的流量转发到realserver.com:80 如果你想,你也可以在你自己的本地机器上循环
ssh -L 12345:localhost:8080 localhost

因此,您可以将应用程序指向本地主机和自定义端口,并且流量将被路由到目标主机:端口。然后你可以退出这个shell(你可能还需要在退出后ctrl+c shell),它会杀死转发,导致你的应用程序看到连接丢失。

有很多好的答案,但最干净的解决方案似乎是这个服务

https://httpstat.us/504?sleep=60000

您可以配置超时时间(最多230秒)和最终返回代码。