本文固定链接,转载请说明出处
一、起因:
最近在做electron,发现ffi-napi在win10上编译能通过,并且能打包win32和linux,在linux上也能运行,这里的linux是指fedora28系统。但是发现如果require(‘ffi-napi’);的时候会报错。原因可能是这个包里面的一个.node文件是windows版本的,于是想着在linux上编译一下。
在虚拟机上装了fedora,使用的root用户,因为用vscode作为编辑器开发,担心执行的时候有限制之类,于是直接用的root用户。结果问题来了,npm install报错。说是权限不够。
二、解决方式:
后来百度了一下,发现早就有人有类似问题,方法如下:
npm install electron --save-dev --unsafe-perm=true --allow-root
也即是在正常的npm install xxx --save-dev 后面加:
--unsafe-perm=true --allow-root
上面是我安装electron的时候代码,依葫芦画瓢,把electron换成其他的照样行。如图:
希望对大家有所帮助。
npm install xxx --unsafe-perm=true --allow-root
npm install -g xxx --unsafe-perm=true --allow-root
三、分析:
1、npm 出于安全考虑不支持以 root 用户运行,即使你用 root 用户身份运行了,npm 会自动转成一个叫 nobody 的用户来运行,而这个用户几乎没有任何权限。这样的话如果你脚本里有一些需要权限的操作,比如写文件(尤其是写 /root/.node-gyp),就会崩掉了。
为了避免这种情况,要么按照 npm 的规矩来,专门建一个用于运行 npm 的高权限用户;要么加 --unsafe-perm 参数,这样就不会切换到 nobody 上,运行时是哪个用户就是哪个用户,即使是 root。