将Google Chrome Puppeteer应用程序推送到Predix时出现错误。

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 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
3个回答

1

0

这是因为Chrome可能需要在该主机上安装更多的软件包才能正常工作。有一个出色的故障排除文档here,假设您对环境如何配置具有一定的控制权。

另一个选择是使用另一个为您运行Chrome的服务(您可以在AWS或Google Cloud上运行它)。这是一个相当复杂的过程,这就是我编写https://browserless.io的原因,它是即插即用的,并支持puppeteer 0.11.0和0.12.0。

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


我对环境没有控制权。所以,大多数时候我将不得不找到另一种方法或者使用你建议的另一个服务。谢谢你的帮助! - Arjun Mudhaliyar

0

看起来Puppeteer试图使用一个缺失或您无权访问的“共享库”。在Predix Cloud Foundry环境中,您对服务器操作系统的访问非常有限。您只能使用容器内部的资源,这使得扩展变得更加容易。

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


1
不,目标是在后端渲染HTML,以便在代码被渲染后生成PDF。没有涉及到用户界面,因此使用后端渲染。谢谢你的帮助! - Arjun Mudhaliyar

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