Chrome headless在Docker中发生未知错误

3

我想使用selenium和nodejs中的webdriver在Docker容器内运行一个无头chrome。我已经创建了一个包含所有必要组件的容器,虽然我可以成功启动无头chrome,但是在一段时间后运行nodejs webdriver测试总是崩溃。

WebDriverError: unknown error: Chrome failed to start: exited abnormally
  (Driver info: chromedriver=2.32.498513 (2c63aa53b2c658de596ed550eb5267ec5967b351),platform=Linux 4.9.41-moby x86_64)
    at WebDriverError (/usr/src/app/node_modules/selenium-webdriver/lib/error.js:27:5)
    at Object.checkLegacyResponse (/usr/src/app/node_modules/selenium-webdriver/lib/error.js:529:15)
    at parseHttpResponse (/usr/src/app/node_modules/selenium-webdriver/lib/http.js:509:13)
    at doSend.then.response (/usr/src/app/node_modules/selenium-webdriver/lib/http.js:441:30)
    at process._tickCallback (internal/process/next_tick.js:109:7)
From: Task: WebDriver.createSession()
    at Function.createSession (/usr/src/app/node_modules/selenium-webdriver/lib/webdriver.js:769:24)
    at Function.createSession (/usr/src/app/node_modules/selenium-webdriver/chrome.js:761:15)
    at createDriver (/usr/src/app/node_modules/selenium-webdriver/index.js:170:33)
    at Builder.build (/usr/src/app/node_modules/selenium-webdriver/index.js:642:16)
    at Object.<anonymous> (/usr/src/app/selenium.js:19:4)
    at Module._compile (module.js:570:32)
    at Object.Module._extensions..js (module.js:579:10)
    at Module.load (module.js:487:32)
    at tryModuleLoad (module.js:446:12)
    at Function.Module._load (module.js:438:3)

完整代码也可以在这里看到。

我的Dockerfile大致如下:

FROM debian:sid

# Install deps + add Chrome Stable + purge all the things
RUN apt-get update && apt-get install -y \
    apt-transport-https \
    ca-certificates \
    curl unzip \
  gnupg \
    --no-install-recommends \
    && curl -sSL https://dl.google.com/linux/linux_signing_key.pub | apt-key add - \
    && echo "deb [arch=amd64] https://dl.google.com/linux/chrome/deb/ stable main" > /etc/apt/sources.list.d/google-chrome.list \
    && apt-get update && apt-get install -y \
    nodejs npm google-chrome-stable \
    --no-install-recommends \
    && apt-get purge --auto-remove -y gnupg \
    && rm -rf /var/lib/apt/lists/*

# Add Chrome as a user
RUN groupadd -r chrome && useradd -r -g chrome -G audio,video chrome \
    && mkdir -p /home/chrome && chown -R chrome:chrome /home/chrome

# Add app and install dependencies
WORKDIR /usr/src/app
RUN chown -R chrome: /usr/src/app
USER chrome
COPY . .
RUN npm install

ENV DBUS_SESSION_BUS_ADDRESS=/dev/null

CMD ["node", "selenium.js"]

我尝试过几个版本,但总体来说基本相同。

我的 Asp npm 依赖如下:

"chromedriver": "^2.32.0",
"selenium-webdriver": "^3.5.0"

我的代码是一个简单的“hello world”,在我的常用电脑上运行得非常顺畅。

const fs = require('fs');
const webdriver = require('selenium-webdriver');
const chromedriver = require('chromedriver');

// const PATH_TO_CHROME = 'C:\\Program Files (x86)\\Google\\Chrome\\Application\\chrome.exe';
const PATH_TO_CHROME = '/usr/bin/google-chrome';

const chromeCapabilities = webdriver.Capabilities.chrome();
chromeCapabilities.set('chromeOptions', {
  binary: PATH_TO_CHROME,
  'args': [
    '--headless --window-size=800,600 --disable-gpu',
  ]
});

const driver = new webdriver.Builder()
  .forBrowser('chrome')
  .withCapabilities(chromeCapabilities)
  .build();

// Navigate to google.com, enter a search.
driver.get('https://www.google.com/ncr');
driver.findElement({ name: 'q' }).sendKeys('webdriver', webdriver.Key.RETURN);
driver.wait(webdriver.until.titleIs('webdriver - Google Search'), 1000);

// Take screenshot of results page. Save to disk.
driver.takeScreenshot().then(base64png => {
  fs.writeFileSync('screenshot.png', new Buffer(base64png, 'base64'));
});

driver.quit();

最终,我使用以下方式运行所有内容:
docker run --rm --cap-add=SYS_ADMIN headless

发生了什么?我不知道如何获取更多的日志详细信息。我阅读了有关在Docker中运行Chrome的特殊性的不同文章,但似乎有些东西阻止了我的WebDriver正常工作。
我填写了一个问题报告,以跟踪此问题。报告链接:https://bugs.chromium.org/p/chromedriver/issues/detail?id=1972
2个回答

2
问题在于传递Chrome参数。它是一个数组,应该像在CLI中一样这样传递。
  chromeCapabilities.set('chromeOptions', {
    binary: PATH_TO_CHROME,
    'args': [
      '--headless', '--verbose', '--window-size=1920,1080', '--ignore-certificate-errors'
    ]
  });

之后该错误不再显示。

0

我的问题是关于在容器内使用Node中的Webdriver,而不是独立的Java服务器。无论如何,独立映像也会发生相同的错误。它不基于debian,而是基于Ubuntu16.04,该版本附带了旧的Node版本,因此您需要使用脚本安装Node。 - guillem

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接