我用以下内容启动了一个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和会话超时