我启动了一个 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控制台与相应浏览器失去了连接。
为什么会发生这种情况以及如何避免这种情况?如果我不使用远程网络驱动程序,则不会发生这种情况。
选项 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
| 归档时间: |
|
| 查看次数: |
7095 次 |
| 最近记录: |