webdriver selenium org.openqa.selenium.remote.UnreachableBrowserException: Error communicating with

对于在使用webdriver和selenium的时候,如果使用过findelement这个函数时,机器有时会报错:

org.openqa.selenium.remote.UnreachableBrowserException: Error communicatingwith the remote browser. It may have died.


出现这个问题的原因一直找不到,而且,出现的时机并不固定。最后才发现问题是socket连接达到上限,原因是由于:webdriver在请求服务以后关闭连接,但是tcp的机制是这个连接不能马上关闭,而是把状态置为time_wait.,如果此时你用netstat查看自己的网络连接,会发现大量的tcp连接处于time_wait状态,导致请求连接达到上限,无法继续请求新的连接。

解决办法:

增大tcp最大连接数

修改注册表中HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\Tcpip\Parameters\MaxUserPort

设置 MaxUserPort = 0xFFFE(65534), 如没有此项则新建,类型为:DWORD 值。修改以上设置后,需要重启系统生效。

减少time_wait时间:


修改注册表中HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\Tcpip\Parameters\TCPTimedWaitDelay

设置TCPTimedWaitDelay =30如没有此项则新建,类型为: DWORD 值。修改以上设置后,需要重启系统生效。


但是还是很纳闷,我都释放socket连接,但是为什么还是不释放。查了资料才明白。

1、客户端是调用函数close(),这时,客户端会发送一个FIN给服务器。
    2、服务器收到FIN,关闭套接字读通道,并将自己状态设置为CLOSE_WAIT(表示被动关闭),并返回一个ACK给客户端。
    3、客户端收到ACK,关闭套接字写通道
    这是两次握手,接下来,服务器会调用close()
    1、服务器close(),发送一个FIN到客户端。
    2、客户端收到FIN,关闭读通道,并将自己状态设置成TIME_WAIT,发送一个ACK给服务器。
    3、服务器收到ACK,关闭写通道,并将自己状态设置为CLOSE。
    4、客户端等待两个最大数据传输时间,然后将自己状态设置成CLOSED。\

TIME_WAIT状态的作用:
    1、保证全双工通信可靠关闭:如果不设置TIME_WAIT状态,直接设置成CLOSED状态,那么服务器得不到回复,会一直发送FIN给客户端。
    2、保证这次连接的重复数据段从网络中消失。如果不设置,那么最后一个回复的时候,需要建立一个socket,端口号可能跟现在的不一样,服务器就会认为是另外的端口号发来的,从而出现数据混乱。


你可能感兴趣的:(webdriver,selenium)