我刚刚通过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 set prefix '~/.npm_packages'
PATH=$PATH:$HOME/.npm_packages/bin; export PATH

其他回答

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

sudo chown -R $USER ~/tmp

没关系!

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

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

之后,npm工作正常!

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

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,了解如何自动执行上述步骤

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

我遇到了这个问题,虽然~/.npm应该归用户所有,但npm并没有在那里安装模块。

真正解决我问题的是这些命令:

npm config set prefix ~/.npm
export PATH="$PATH:$HOME/.npm/bin"

它将确保您的所有全局安装都使用此前缀。用户拥有这个目录很重要。

对于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