Selenium:闲置几分钟后“无法找到带 ID 的会话”

Ano*_*use 6 python selenium

我启动了一个 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
Run Code Online (Sandbox Code Playgroud)

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

然后我等了一段时间(大约15分钟)然后跑了driver.title,看起来Python控制台与相应浏览器失去了连接。

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

Max*_*nka 7

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

来自 docker/selenium 文档:

Grid 的默认会话超时为 300 秒,其中会话可以处于陈旧状态,直到被终止。您可以使用 SE_NODE_SESSION_TIMEOUT 以秒为单位覆盖该值。

docker run -d -e SE_NODE_SESSION_TIMEOUT=1000 --shm-size="4g" --hostname selenium_firefox selenium/standalone-firefox
Run Code Online (Sandbox Code Playgroud)

选项 2:每 60 秒(任何 < 300)秒 Ping 一次您的会话

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

for x in range(15):
    time.sleep(60)
    driver.current_url
Run Code Online (Sandbox Code Playgroud)

参考

https://github.com/SeleniumHQ/docker-selenium#grid-url-and-session-timeout