Мне нужно запустить скрипт Python, который использует веб-драйвер Selenium:
import platform
from selenium import webdriver
from pyvirtualdisplay import Display
driver = None
if platform.system() == 'Linux':
print("Initializing browser for chrome...")
DISPLAY = Display(visible=0, size=(800, 600))
DISPLAY.start()
print("Started display")
chrome_options = webdriver.ChromeOptions()
chrome_options.add_argument('--no-sandbox')
driver = webdriver.Chrome('/usr/local/bin/chromedriver', chrome_options=chrome_options)
print("Done init chrome")
connected = True
else:
try:
print("Starting firefox...")
driver = webdriver.Firefox()
connected = True
except:
print("Could not connect through firefox")
if driver:
print("driver ok")
driver.quit()
print("All ok")
Скрипт запускается нормально из консоли:
sudo ~/environments/scrapers/bin/python test_webdriver.py
Initializing browser for chrome...
Started display
Done init chrome
driver ok
All ok
Но выдает ошибку WebDriverException при попытке запустить с помощью строфы exec с Upstart:
Initializing browser for chrome...
Started display
...
selenium.common.exceptions.WebDriverException: Message: unknown error: Chrome failed to start: exited abnormally
(Driver info: chromedriver=2.26.436382 (70eb799287ce4c2208441fc057053a5b07ceabac),platform=Linux 4.8.0-58-generic x86_64)
Я добавил, возможно, отсутствующие пути в скрипт выскочки, например
env PYTHON_HOME=/home/rsa-key-20161031/environments/scrapers
env PATH=/usr/local/bin:/usr/bin:$PYTHON_HOME:$PATH
env ENV=production
env DISPLAY=:10
chdir /home/user/project
console log
exec $PYTHON_HOME/bin/python test_webdriver.py
Без эффекта. Поиск ошибки ничего конкретного по этому поводу не дает. Любое понимание того, как заставить эту работу работать, очень ценится.
Обновление: Мое текущее решение — использовать Cron, так как у него нет проблем с использованием Xvfb. Я все еще очень хотел бы знать, можно ли запустить задачу веб-драйвера как службу. Я также пытался использовать Selenium в качестве удаленного веб-драйвера с теми же отрицательными результатами (Chrome завершает работу после того, как, по-видимому, не может подключиться к виртуальному дисплею)