Я пытаюсь запустить селен с хромом без головы в следующих условиях:
- ОС: Ubuntu 16.04.6
- Chrome: 77.0.3865.90 (Официальная сборка) (64-разрядная версия)
- ChromeDriver: 77.0.3865.40
- Версия сервера Selenium: 3.141.59, версия: e82be7d358
Я читал об этом на developer.google.com и следовал рекомендациям Запуск Selenium с Headless Chrome . Я следовал инструкциям в ipython REPL:
from selenium import webdriver
options = webdriver.ChromeOptions()
options.binary_location = '/usr/local/bin'
options.add_argument('headless')
options.add_argument('window-size=1200x600')
driver = webdriver.Chrome(chrome_options=options)
Но это приводит к следующей ошибке:
WebDriverException Traceback (most recent call last)
<ipython-input-6-658404e774ae> in <module>()
----> 1 driver = webdriver.Chrome(chrome_options=options)
/home/user/.local/lib/python2.7/site-packages/selenium/webdriver/chrome/webdriver.pyc in __init__(self, executable_path, port, options, service_args, desired_capabilities, service_log_path, chrome_options, keep_alive)
79 remote_server_addr=self.service.service_url,
80 keep_alive=keep_alive),
---> 81 desired_capabilities=desired_capabilities)
82 except Exception:
83 self.quit()
/home/user/.local/lib/python2.7/site-packages/selenium/webdriver/remote/webdriver.pyc in __init__(self, command_executor, desired_capabilities, browser_profile, proxy, keep_alive, file_detector, options)
155 warnings.warn("Please use FirefoxOptions to set browser profile",
156 DeprecationWarning, stacklevel=2)
--> 157 self.start_session(capabilities, browser_profile)
158 self._switch_to = SwitchTo(self)
159 self._mobile = Mobile(self)
/home/user/.local/lib/python2.7/site-packages/selenium/webdriver/remote/webdriver.pyc in start_session(self, capabilities, browser_profile)
250 parameters = {"capabilities": w3c_caps,
251 "desiredCapabilities": capabilities}
--> 252 response = self.execute(Command.NEW_SESSION, parameters)
253 if 'sessionId' not in response:
254 response = response['value']
/home/user/.local/lib/python2.7/site-packages/selenium/webdriver/remote/webdriver.pyc in execute(self, driver_command, params)
319 response = self.command_executor.execute(driver_command, params)
320 if response:
--> 321 self.error_handler.check_response(response)
322 response['value'] = self._unwrap_value(
323 response.get('value', None))
/home/user/.local/lib/python2.7/site-packages/selenium/webdriver/remote/errorhandler.pyc in check_response(self, response)
240 alert_text = value['alert'].get('text')
241 raise exception_class(message, screen, stacktrace, alert_text)
--> 242 raise exception_class(message, screen, stacktrace)
243
244 def _value_or_default(self, obj, key, default):
WebDriverException: Message: unknown error: Chrome failed to start: exited abnormally
(unknown error: DevToolsActivePort file doesn't exist)
(The process started from chrome location /usr/local/bin is no longer running, so ChromeDriver is assuming that Chrome has crashed.)
Я искал вокруг и нашел это ответ. Я видел, что аргумент 'headless'
передается так: add_argument("--headless")
. Я пытался добавить его с '--'
, но с тем же исключением, что и результат.
В этот комментарий также рекомендуется аргумент --no-sandbox
, но добавление этого аргумента ничего не меняетв моем случае ни один.
Как я могу отладить и исправить эту ошибку?
Обновление на основе ответа от Wonka:
Я изменилсяoptions.add_argument('headless')
до options.add_argument('--headless')
и options.add_argument('window-size=1200x600')
до options.add_argument('--window-size=1200x600')
с той же ошибкой, что и выше.
Затем, как было рекомендовано, я попытался установить разрешение после driver = webdriver.Chrome(chrome_options=options)
, но эта строка уже не работает.