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

当前回答

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

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

之后,npm工作正常!

其他回答

以上所有内容都是不必要的。

我遇到的问题是我在运行NPM时使用了-g。我无法理解我是如何在项目中创建“npm_module”文件夹的。

解决方案是运行“NPM init”。这将创建一个“package.json”和“NPM_module”文件夹,所有后续模块都将加载到该文件夹中。运行npm时,不要使用-g使用-s更新“package.json”文件。

这是一个很好的视频,解释

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

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

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

# 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年后,我建议使用节点版本管理器。它为你节省了很多时间和麻烦。

我将我的用户帐户设置为/usr/local目录的所有者,这样就可以在那里发出正常命令。

sudo chown-R$USER/usr/local

参考:http://howtonode.org/introduction-to-npm

对我来说,只执行

sudo chown -R $(whoami) ~/.npm

不起作用。然后,我也执行

sudo chown -R $(whoami) /usr/lib/node_modules/
sudo chown -R $(whoami) /usr/bin/node
sudo chown -R $(whoami) /usr/bin/npm

一切都很好!

TL;博士

在运行npm安装以安装全局包时,请始终使用sudo-i或sudo-H。


当您使用npm时,它会将包下载到您的用户主目录。当您以sudo身份运行时,npm会将文件安装到同一目录中,但现在它们归root用户所有。

所以,这是每一个使用过npm的人都会遇到的情况:

使用npm install foo毫无问题地安装一些本地软件包使用sudo install-g foo-cli安装全局软件包,无问题尝试使用npm安装栏安装本地软件包对npm设计者感到沮丧,因为你必须重新创建一个目录

在sudo中使用-i或-H选项时,主目录将是root的主目录。任何全局安装都会将包缓存到/root/.npm,而不是/home/me/.npm中的root拥有的文件。

只要在运行npm安装来安装全局包时始终使用sudo-i或sudo-H,您的npm权限问题就会迎刃而解。

永远。

--问:修复一个已经一团糟的npm的公认答案。