我刚刚通过nodejs.org上的包安装了node和npm,每当我尝试使用npm搜索或安装某个东西时,它会抛出以下错误,除非我执行命令。我觉得这是权限问题?我已经是管理员了。
npm ERR! Error: EACCES, open '/Users/chietala/.npm/-/all/.cache.json'
npm ERR! { [Error: EACCES, open '/Users/chietala/.npm/-/all/.cache.json']
npm ERR! errno: 3,
npm ERR! code: 'EACCES',
npm ERR! path: '/Users/chietala/.npm/-/all/.cache.json' }
npm ERR!
npm ERR! Please try running this command again as root/Administrator.
npm ERR! System Darwin 12.2.0
npm ERR! command "node" "/usr/local/bin/npm" "search" "bower"
npm ERR! cwd /Users/chietala
npm ERR! node -v v0.10.4
npm ERR! npm -v 1.2.18
npm ERR! path /Users/chietala/.npm/-/all/.cache.json
npm ERR! code EACCES
npm ERR! errno 3
npm ERR! stack Error: EACCES, open '/Users/chietala/.npm/-/all/.cache.json'
npm ERR!
npm ERR! Additional logging details can be found in:
npm ERR! /Users/chietala/npm-debug.log
npm ERR! not ok code 0
在我看来,最好的选项是npm文档中建议的选项,即首先通过运行npm-config-get-prefix检查全局node_module的默认安装位置。如果像我在Trusty/usr上所做的那样,您可能希望将其更改为一个可以安全拥有的文件夹,而不会像我那样弄乱事情。
为此,请在系统中选择或创建一个新文件夹。为了保持一致性,您可能希望将其放在主目录中,或者像我一样放在/usr/local下,因为我也是Mac用户(我不需要根据我恰好在前面的机器查看不同的位置)。这样做的另一个很好的原因是,/usr/local文件夹可能已经在您的PATH中(除非您想乱用PATH),但新创建的文件夹可能不在其中,您需要自己在.bash配置文件或.bashrc文件中将其添加到PATH中。
长话短说,我使用npm config设置前缀“/usr/local”更改了全局模块的默认位置,创建了/usr/local/lib/node_modules文件夹(它将由npm使用),并使用以下命令更改了npm使用的文件夹的权限:
sudo chown -R $(whoami) $(npm config get prefix)/{lib/node_modules,bin,share}
现在,您可以安全地全局安装任何模块。希望这有帮助!
小心!!!小心!!!小心!!!
chown或chmod不是解决方案,因为存在安全风险。
相反,请执行以下操作:
首先检查npm指向的位置,如果您调用:
npm config get prefix
如果返回/usr,则可以执行以下操作:
mkdir ~/.npm-global
export NPM_CONFIG_PREFIX=~/.npm-global
export PATH=$PATH:~/.npm-global/bin
这将在主目录中创建一个npm目录,并将npm指向它。
要使这些更改永久化,必须将export命令添加到.bashrc中:
echo -e "export NPM_CONFIG_PREFIX=~/.npm-global\nexport PATH=\$PATH:~/.npm-global/bin" >> ~/.bashrc
当尝试以root用户身份全局安装软件包时,如果使用EUIDLOOKUP或EACES或npm,该过程将失败。这将打乱用户的全局软件包权限。
为了理解这个问题,我建议阅读这个问题。简而言之,npm尝试使用当前进程的EUID来运行安装脚本,而不是作为root用户,而是作为运行npm的原始用户,同时假设作为root用户运行的用户将使用sudo,因此将设置EUID。
这就是为什么@JHM16基于使用sudo的答案应该有效。
但在容器构建中安装包时情况并非如此。在容器中,sudo经常会丢失。而build通常只作为root运行。
当然,容器构建可以更改为以普通用户的身份运行这些命令,并以该用户的身份构建所有内容。但这不会使构建更安全,在某些情况下可能是不可取的。
因此,在容器构建中,以下是如何使npm全局安装工作的方法,例如使用yarn包。
# setpriv --ruid 0 --euid 0 npm --unsafe-perm install -g yarn
setpriv是一个小型的低级实用程序,应该可以在任何linux发行版上使用或轻松安装。