我刚刚通过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

当前回答

当尝试以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发行版上使用或轻松安装。

其他回答

在没有sudo的情况下,我在NPM模块上也遇到了类似的问题。问题是,当我安装节点时,我通过chris/lea ppa repo使用sudo进行了安装。

我的解决方案是卸载节点,然后按以下方式安装:

从nodejs.org#下载最新的稳定节点源代码,在我的例子中是node-v0.10.20.tar.gz

tar-zxf node-v0.10.20.tar.gz#解压缩源cd node-v0.10.20#输入未压缩文件夹sudo chown$USER-R/usr/local./configure--prefix=/usr/local&&make&&makeinstall

PD:如果您不想更改/usr/local文件夹的所有权,可以将其安装在您已经拥有的位置。这种方法的问题是,您必须将安装文件夹与bash命令行绑定,以便稍后使用node命令

mkdir~/opt./configure--prefix=~/opt&&make&&makeinstallecho'export PATH=~/opt/bin:${PATH}'>~/.bashrc#或~/.profile或~/.bash _profile或~/.zshenv,具体取决于当前操作系统

使用这两种方法中的任何一种,您都可以在不使用sudo的情况下执行以下操作

npm安装-g模块安装

事实上,我也有同样的问题。我在运行Ubuntu。我的问题出现了,因为我丢失了Ubuntu的公钥。甚至没有更新我的系统。它给出了GPG错误。在这种情况下,您可以使用以下命令重新获取密钥:

sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys <key in GPG error>

之后,npm工作正常!

小心!!!小心!!!小心!!!

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

对于Mac(采用Christoper Will的答案)

Mac OS X 10.9.4

系统首选项>用户和组>(解锁)>按+:新建帐户>“组”帐户名:nodegrp创建组后,勾选要包含在此组中的用户sudo chgrp-R nodegrp/usr/local/lib/node_modules/sudo chgrp nodegrp/usr/bin/nodesudo chgrp节点组/usr/bin/npmsudo chown-R$(whoami):nodegrp~/.npm

我在安装凹槽时遇到了这个问题(https://github.com/twitter/recess)为Bootstrap 3编译CSS。

安装凹槽时:

-npm install recess -g

你需要解锁主目录中的权限,比如Noah说:sudo chown-R`whoami`~/.npm您还需要对node_modules目录的写入权限,如Xilo因此,如果它仍然不起作用,请尝试:sudo chown-R“whoami”/usr/local/lib/node_modules如果仍然看到错误,可能还需要更正/usr/local权限:sudo chown-R“whoami”/usr/local

请注意,如本文所述,如果您在Mac上,/usr/local/实际上不是一个系统目录,因此,这个答案实际上对Mac用户来说非常“安全”。然而,如果您使用的是Linux,请参阅Christopher Will下面的答案,以获得一个多用户友好、系统目录安全(但更复杂)的解决方案。