Selenium:怠速几分钟后"Unable to find session with ID"



我用以下内容启动了一个Docker容器:docker run -d --shm-size="4g" --hostname selenium_firefox selenium/standalone-firefox

在另一个带有Python的容器中:

...
>>> driver = webdriver.Remote(command_executor="http://" +selenium_host+":4444/w
d/hub", desired_capabilities=DesiredCapabilities.FIREFOX, keep_alive=True)      
       
>>> driver.title                                                                
''                                                                              
>>> driver.title                                                                
Traceback (most recent call last):                                              
File "<stdin>", line 1, in <module>                                           
File "/usr/local/lib/python3.10/site-packages/selenium/webdriver/remote/webdri
ver.py", line 447, in title                                                     
resp = self.execute(Command.GET_TITLE)                                      
File "/usr/local/lib/python3.10/site-packages/selenium/webdriver/remote/webdri
ver.py", line 424, in execute                                                   
self.error_handler.check_response(response)                                 
File "/usr/local/lib/python3.10/site-packages/selenium/webdriver/remote/errorh
andler.py", line 247, in check_response                                         
raise exception_class(message, screen, stacktrace)                          
selenium.common.exceptions.WebDriverException: Message: Unable to execute reques
t for an existing session: Unable to find session with ID: 5c619451-8361-4ec9-9b
7e-58b7afac15ff                                                                 
Build info: version: '4.1.1', revision: 'e8fcc2cecf'                            
System info: host: 'selenium_firefox', ip: '172.17.0.3', os.name: 'Linux', os.ar
ch: 'amd64', os.version: '5.4.0-89-generic', java.version: '11.0.13'            
Driver info: driver.version: unknown

在创建远程网络驱动程序后,我立即运行了第一个driver.title

然后我等待了一段时间(大约15分钟(,再次运行driver.title,Python控制台似乎已经失去了与相应浏览器的连接。

为什么会发生这种情况,我该如何避免?如果我不使用远程网络驱动程序,就不会发生这种情况。

选项1:覆盖Docker Selenium Grid默认会话超时

来自docker/selenium文档:

网格的默认会话超时为300秒,会话可以处于过时状态,直到终止。您可以使用SE_NODE_SESSION_TIMEOUT以秒为单位覆盖该值。

docker run -d -e SE_NODE_SESSION_TIMEOUT=1000 --shm-size="4g" --hostname selenium_firefox selenium/standalone-firefox

选项2:每60秒(任意<300(Ping一次会话

在空闲时间期间,您可以循环执行一些驱动程序命令

for x in range(15):
time.sleep(60)
driver.current_url

参考

https://github.com/SeleniumHQ/docker-selenium#grid-url和会话超时

相关内容

  • 没有找到相关文章

最新更新