permission denied, mkdir '/root/.nvm/versions/node/v9.11.1/lib/node_modules/

permission denied, mkdir '/root/.nvm/versions/node/v9.11.1/lib/node_modules/

BUG集散地

2019-09-12 08:54 阅读 25 喜欢 0 puppeteer安装

错误信息: permission denied, mkdir '/root/.nvm/versions/node/v9.11.1/lib/node_modules/

今天想在服务器上跑下自己自动签到的程序,需要安装puppeteer ,结果出错。

找了下资料,发现还有不少人出这样的问题,参考 https://github.com/npm/npm/issues/17268

最终使用以下命令,还未安装成功,不过没有报错。

npm install puppeteer -g --unsafe-perm=true --allow-root

等安装完成,继续回来更。

安装完成了,经历了几次的无故断掉后,终于下载完了,可以试试跑下小东西了。

结果:

(node:11117) UnhandledPromiseRejectionWarning: Error: Failed to launch chrome!
/home/web/toy/node_modules/puppeteer/.local-chromium/linux-674921/chrome-linux/chrome: error while loading shared libraries: libXcomposite.so.1: cannot open shared object file: No such file or directory


TROUBLESHOOTING: https://github.com/GoogleChrome/puppeteer/blob/master/docs/troubleshooting.md

    at onClose (/home/web/toy/node_modules/puppeteer/lib/Launcher.js:349:14)
    at Interface.helper.addEventListener (/home/web/toy/node_modules/puppeteer/lib/Launcher.js:338:50)
    at Interface.emit (events.js:185:15)
    at Interface.close (readline.js:379:8)
    at Socket.onend (readline.js:152:10)
    at Socket.emit (events.js:185:15)
    at endReadableNT (_stream_readable.js:1106:12)
    at process._tickCallback (internal/process/next_tick.js:178:19)

f**k, 从来就没顺利的时候,全靠运气...

然后找了下资料,发现缺少依赖库,安装依赖库:

# 依赖库
sudo yum install pango.x86_64 libXcomposite.x86_64 libXcursor.x86_64 libXdamage.x86_64 libXext.x86_64 libXi.x86_64 libXtst.x86_64 cups-libs.x86_64 libXScrnSaver.x86_64 libXrandr.x86_64 GConf2.x86_64 alsa-lib.x86_64 atk.x86_64 gtk3.x86_64 -y

#依赖字体
yum install ipa-gothic-fonts xorg-x11-fonts-100dpi xorg-x11-fonts-75dpi xorg-x11-utils xorg-x11-fonts-cyrillic xorg-x11-fonts-Type1 xorg-x11-fonts-misc -y

继续执行,还是报错,不过错误已经不一样了(仿佛看到了胜利的希望..)

(node:11792) UnhandledPromiseRejectionWarning: Error: Failed to launch chrome!

(chrome:11806): Gtk-WARNING **: 15:11:04.104: cannot open display: 


TROUBLESHOOTING: https://github.com/GoogleChrome/puppeteer/blob/master/docs/troubleshooting.md

    at onClose (/home/web/toy/node_modules/puppeteer/lib/Launcher.js:349:14)
    at ChildProcess.helper.addEventListener (/home/web/toy/node_modules/puppeteer/lib/Launcher.js:339:60)
    at ChildProcess.emit (events.js:185:15)
    at Process.ChildProcess._handle.onexit (internal/child_process.js:209:12)

这个问题我这边是沙箱的问题,修改以下代码:

const browser = await puppeteer.launch({args: ['--no-sandbox', '--disable-setuid-sandbox']});
// '--no-sandbox' 与 '--disable-setuid-sandbox' 一起使用。

绝望来临了,修复后以上错误都不报错了,但是超时.. 超时

TimeoutError: Navigation Timeout Exceeded: 30000ms exceeded
    at Promise.then (/home/web/toy/node_modules/puppeteer/lib/LifecycleWatcher.js:142:21)
    at <anonymous>
  -- ASYNC --
    at Frame.<anonymous> (/home/web/toy/node_modules/puppeteer/lib/helper.js:111:15)
    at Page.goto (/home/web/toy/node_modules/puppeteer/lib/Page.js:674:49)
    at Page.<anonymous> (/home/web/toy/node_modules/puppeteer/lib/helper.js:112:23)
    at /home/web/toy/autosign/sign.js:96:20
    at <anonymous>
    at process._tickCallback (internal/process/next_tick.js:182:7) name: 'TimeoutError' 

不管访问什么地址,百度也好,京东也好,一律超时,但是在我本地是没有问题的,只是在linux 服务器上有这个问题,还在查找验证中...


对chromium做了下简单的优化,提升还是很明显能感觉出来的。

let args = [
            '--no-sandbox',
            '--disable-setuid-sandbox',
            '--disable-gpu',
            '--disable-dev-shm-usage',
            '--no-first-run',
            '--no-zygote',
            '--single-process',
            '--disable-infobars',
        ];
        const browser = await puppeteer.launch({
            args : args
        });

而且,没想到的是(可能确实是网络问题),增加了几个参数优化了下后,竟然不超时了... [真神奇.jpg]


以上参考于:

转载请注明出处: https://chrunlee.cn/article/nodejs-puppeteer-install-error.html


如果对你有用的话,请赏给作者一个馒头吧 ...或帮点下页面底部的广告,感谢!!

赞赏支持
提交评论
评论信息(请文明评论)
暂无评论,快来快来写想法...
推荐
在使用marked来做md解析的时候,部分解析规则可能并不是很如意,比如说,我在md中写了a标签,但是这些标签都是在当前页面替换的,而我想要的是新打开窗口。
使用nodejs连接ftp,进行ftp的操作,包括列表、上传、下载以及速率等。
因为自己的记录笔记的应用是有道云,又想着把有道云跟自己的小网站联通起来,所以查找了有道云的,然后实现了nodejs版本的sdk.
前段时间学习到了nodejs的net模块这部分,正好想实现一个局域网内的文件下载小demo,噔噔噔噔... 兴趣推动 ,马上搞一搞。
通过pm2来实现nodejs应用的集群,不过我之前没做session共享,导致.. 登录不上啊 啊啊啊,无奈,又重新对redis进行了集成。
目前了解的有两个模块可以实现二维码的模块,一个是node-qrcode ,这个算是比较大众的,不过环境比较复杂,所以...连看都没看;还有一个是小众的 qr-image ,这个比较简单,没有其他环境依赖,安装即可用,因为要实现一个简单的在线二维码生成,就先用这个试试水了
跑了一个千库网的自动签到,在windows上测试的时候好好的,图片也没问题,可是放到linux服务器就不行了,总是登录不上不说,图片都不一样
写文章总会需要一些素材,但是好多素材都是收费或有限制的,还是我要求不高,在千库网看了下还不错,有各签到还送VIP,于是就有了想法....