4

我正在尝试在 predix-web-starter 应用程序中使用 Google Chrome Puppeteer。当我在 Windows 上本地运行代码时,它运行完美。在我将它推送到 Predix 之后,当我运行包含 Puppeteer 代码的部分时,它会导致错误。似乎缺少一些库问题(不确定是什么)。简而言之,我怎样才能让 Puppeteer 在 Predix 上运行?

Predix-web-starter:https ://github.com/PredixDev/predix-webapp-starter Puppeteer:https ://www.npmjs.com/package/puppeteer

傀儡代码:

const puppeteer = require('puppeteer');
(async () => {
const browser = await puppeteer.launch();
const page = await browser.newPage();
await page.goto('https://news.ycombinator.com', {waitUntil: 'networkidle'});
await page.pdf({path: 'hn.pdf', format: 'A4'});
await browser.close();
})();

日志:

2017-11-07T12:40:16.19+0530 [App/0] ERR /home/vcap/app/node_modules/puppeteer/.local-chromium/linux-508693/chrome-linux/chrome: error while loading shared libraries: libX11-xcb.so.1: cannot open shared object file: No such file or directory
2017-11-07T12:40:16.19+0530 [App/0] ERR TROUBLESHOOTING: https://github.com/GoogleChrome/puppeteer/blob/master/docs/troubleshooting.md
2017-11-07T12:40:16.19+0530 [App/0] ERR     at Interface.close (readline.js:319:8)
2017-11-07T12:40:16.19+0530 [App/0] ERR     at endReadableNT (_stream_readable.js:974:12)
2017-11-07T12:40:16.19+0530 [App/0] ERR Potentially unhandled rejection [3] Error: Failed to launch chrome!
2017-11-07T12:40:16.19+0530 [App/0] ERR     at onClose (/home/vcap/app/node_modules/puppeteer/node6/Launcher.js:262:14)
2017-11-07T12:40:16.19+0530 [App/0] ERR     at emitNone (events.js:91:20)
2017-11-07T12:40:16.19+0530 [App/0] ERR     at Interface.emit (events.js:186:7)
2017-11-07T12:40:16.19+0530 [App/0] ERR     at _combinedTickCallback (internal/process/next_tick.js:74:11)
2017-11-07T12:40:16.19+0530 [App/0] ERR     at Interface.helper.addEventListener (/home/vcap/app/node_modules/puppeteer/node6/Launcher.js:251:50)
2017-11-07T12:40:16.19+0530 [App/0] ERR     at Socket.onend (readline.js:106:10)
2017-11-07T12:40:16.19+0530 [App/0] ERR     at emitNone (events.js:91:20)
2017-11-07T12:40:16.19+0530 [App/0] ERR     at Socket.emit (events.js:186:7)
2017-11-07T12:41:15.21+0530 [RTR/2] OUT puppeter-arjun-app.run.aws-usw02-pr.ice.predix.io - [2017-11-07T07:10:16.196+0000] "GET /puppeteer HTTP/1.1" 502 0 67 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/62.0.3202.75 Safari/537.36" "10.72.11.93:2263" "10.72.2.213:61322" x_forwarded_for:"-" x_forwarded_proto:"http" vcap_request_id:"7d0f3007-914a-42d4-536d-b94eb8d2fb6c" response_time:59.022647288 app_id:"02063159-96d9-43c5-a3e9-77f4e72339f4" app_index:"-" x_b3_traceid:"4f11f468be4b6817" x_b3_spanid:"4f11f468be4b6817" x_b3_parentspanid:"-"
2017-11-07T12:41:15.21+0530 [RTR/2] OUT
4

3 回答 3

1

最近发现使用cloudfoundry/apt-buildpackcloudfoundry/nodejs-buildpack,可以通过将它们包含在 apt.yml 中来安装共享库。但是 predix 不允许 multibuildpacks 推送,所以我尝试使用cloudfoundry/multi-buildpack没有成功,原因不明。我解决它的方法是创建一个自定义构建包,从 apt 获取代码,将其放在 nodejs buildpack 上,然后在 manifest.yml 中包含 git 存储库 url。这是我的自定义 buildpack

于 2018-08-02T21:58:48.183 回答
0

这是因为 Chrome 可能需要安装更多软件包才能在该主机上正常工作。这里有一个很好的故障排除文档,假设您可以控制环境的配置方式。

另一个选项是使用另一个为您运行 Chrome 的服务(您可以在 AWS 或 Google Cloud 上工作)。这是一个相当大的过程,这就是我写https://browserless.io的原因,它是交钥匙的,支持 puppeteer 0.11.0 和 0.12.0。

希望这能让你走上正确的道路,祝你好运!

于 2017-11-12T00:02:42.070 回答
0

看起来 puppeteer 正在尝试使用缺少或您无权访问的“共享库”。在 Predix Cloud Foundry 环境中,您对服务器操作系统的访问非常有限。您只能使用容器内的资源,这样可以轻松进行扩展。

你的目标是什么?尝试运行浏览器测试?您可以尝试使用 Sauce Labs 或 Travis 使用 selenium。

于 2017-11-13T17:40:40.123 回答