Селен установки с ошибкой Chrome без головы: WebDriverException: Сообщение: неизвестная ошибка: Не удалось запустить Chrome: аварийный выход - PullRequest
3 голосов
/ 08 октября 2019

Я пытаюсь запустить селен с хромом без головы в следующих условиях:

  • ОС: 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), но эта строка уже не работает.

1 Ответ

1 голос
/ 08 октября 2019

Несколько изменений, полный путь

#Pass binary on init object
##options.binary_location = '/usr/local/bin/chromedriver'

options.add_argument('--headless')

Дополнительные параметры в моем коде

options.add_argument("--disable-gpu")
options.add_argument("--no-sandbox")
options.add_argument("--disable-dev-shm-usage")

Edit2:

driver = webdriver.Chrome(chrome_options=options, executable_path="/usr/local/bin/chromedriver")

Чтобы установить разрешение, я использую это послеобъект драйвера init

driver.set_window_size(1280, 1024)
...