我正在尝试使用基于miniconda / anaconda的docker容器中的selenium
库运行一些python脚本,但我不断收到此错误:selenium.common.exceptions.WebDriverException: Message: unknown error: Chrome failed to start: exited abnormally
。我还使用xvfb
的python包装器来避免打开真正的Chrome窗口。
要重现此(从正在运行的docker容器中):
root@304ccd3bae83:/opt# python
Python 3.6.4 |Anaconda, Inc.| (default, Jan 16 2018, 18:10:19)
[GCC 7.2.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>>
>>>
>>> from selenium import webdriver
>>> from xvfbwrapper import Xvfb
>>>
>>> with Xvfb(width=1366, height=768) as xvfb:
... my_driver = webdriver.Chrome('/opt/chromedriver/2.33/chromedriver')
...
Traceback (most recent call last):
File "<stdin>", line 2, in <module>
File "/opt/conda/lib/python3.6/site-packages/selenium/webdriver/chrome/webdriver.py", line 69, in __init__
desired_capabilities=desired_capabilities)
File "/opt/conda/lib/python3.6/site-packages/selenium/webdriver/remote/webdriver.py", line 151, in __init__
self.start_session(desired_capabilities, browser_profile)
File "/opt/conda/lib/python3.6/site-packages/selenium/webdriver/remote/webdriver.py", line 240, in start_session
response = self.execute(Command.NEW_SESSION, parameters)
File "/opt/conda/lib/python3.6/site-packages/selenium/webdriver/remote/webdriver.py", line 308, in execute
self.error_handler.check_response(response)
File "/opt/conda/lib/python3.6/site-packages/selenium/webdriver/remote/errorhandler.py", line 194, in check_response
raise exception_class(message, screen, stacktrace)
selenium.common.exceptions.WebDriverException: Message: unknown error: Chrome failed to start: exited abnormally
(Driver info: chromedriver=2.33.506092 (733a02544d189eeb751fe0d7ddca79a0ee28cce4),platform=Linux 4.4.0-116-generic x86_64)
根据这一点:https://sites.google.com/a/chromium.org/chromedriver/help/chrome-doesn-t-start似乎有人可能需要使用适用于所有用户的独立版Chrome,但我不确定docker构建是如何工作的,我想Docker镜像是构建的作为root
,其中的所有代码都以root
执行,因此控制Chrome的不同用户不会有任何问题。
这个python代码在带有X windows的普通Ubuntu笔记本电脑上运行良好。在从正在运行的docker容器中检查时,我需要仔细挑选Chrome和chromedriver的版本:
root@304ccd3bae83:/opt# /opt/chromedriver/2.33/chromedriver --version
ChromeDriver 2.33.506092 (733a02544d189eeb751fe0d7ddca79a0ee28cce4)
root@304ccd3bae83:/opt# google-chrome-stable --version
Google Chrome 62.0.3202.75
答案 0 :(得分:2)
这些选项有助于解决问题。
chrome_options.add_argument('--headless')
chrome_options.add_argument('--no-sandbox')
chrome_options.add_argument("--disable-setuid-sandbox")
在看到Chrome failed to start: crashed
时需要其中一个。
另外:确保使用chrome-driver
ps aux | grep chrome-driver
进程找不到要杀死的PID,没有僵尸(来自之前的执行)。
请记住,如果您使用Python multiprocessing
库来生成涉及他们自己的Chrome浏览器实例的许多进程,那么您就不能使用Docker(它应该只启动一个Python进程,除非使用supervisor
)这样的内容,如果您尝试的话,可能会看到selenium.common.exceptions.WebDriverException: Message: chrome not reachable
。