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

当前回答

在我的情况下,这是因为~/tmp的许可。所以我做了:

sudo chown -R $USER ~/tmp

没关系!

其他回答

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

好像我们需要更多的答案,但无论如何。。

Sindre Sorus有一份在OS X和Linux上不使用sudo的情况下全局安装npm包的指南,概述了如何在不干扰权限的情况下干净地安装:

以下是为给定用户全局安装软件包的方法。为全局包创建目录mkdir“${HOME}/.npm包”在.bashrc/.zshrc中引用此目录以供将来使用:NPM_PACKAGES=“${HOME}/.NPM包”向npm指明存储全局安装包的位置。在$HOME/.npmrc文件中添加:prefix=${HOME}/.npm包确保节点将找到它们。将以下内容添加到.bashrc/.zshrc中:NODE_PATH=“$NPM_PACKAGES/lib/NODE_modules:$NODE_PATH”确保找到已安装的二进制文件和手册页。将以下内容添加到.bashrc/.zshrc中:PATH=“$NPM_PACKAGES/bin:$PATH”#取消设置manpath,以便我们可以通过`manpath从/etc/manpath继承`#命令unset MANPATH#如果您已经在配置中的其他位置修改了MANPATH,请删除MANPATH=“$NPM_PACKAGES/share/man:$(MANPATH)”查看npm-g_nosudo,了解如何自动执行上述步骤

请查看本指南的来源以获取最新更新。

在没有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模块安装

其他答案是建议将系统目录的所有权或权限更改为特定用户。我强烈反对这样做,这可能会变得非常尴尬,可能会搞乱整个系统!

这里有一种更通用、更安全的方法,也支持多用户。

为节点用户创建新组,并将所需用户添加到此组。然后将依赖于节点的文件/目录的所有权设置为此组。

# Create new group
sudo groupadd nodegrp 

# Add user to group (logname is a variable and gets replaced by the currently logged in user)
sudo usermod -a -G nodegrp `logname`

# Instant access to group without re-login
newgrp nodegrp

# Check group - nodegrp should be listed as well now
groups

# Change group of node_modules, node, npm to new group 
sudo chgrp -R nodegrp /usr/lib/node_modules/
sudo chgrp nodegrp /usr/bin/node
sudo chgrp nodegrp /usr/bin/npm

# (You may want to change a couple of more files (like grunt etc) in your /usr/bin/ directory.)

现在,您可以以用户身份轻松安装模块

npm install -g generator-angular

某些模块(咕噜、弓箭手、溜溜球等)仍需要作为根安装。这是因为它们在/user/bin/中创建符号链接。

Edit

3年后,我建议使用节点版本管理器。它为你节省了很多时间和麻烦。

如果sudo chown-R$(whoami)~/.npm不适合您,或者您需要非终端命令解决方案。

问题是您的用户帐户没有node_modules文件夹的写入权限,因此您可以执行以下操作

打开finder并按cmd+shift+g,这将打开带有url的文件夹编写以下路径/usr/local/lib/node_modules并按go右键单击node_modules文件夹并选择Get Info向下滚动到共享权限部分(&P)解锁以进行更改。按+并添加用户帐户确保在权限下拉列表中选择“读写”

现在,您应该能够在没有sudo的情况下安装软件包,并且应该解决权限问题