我刚刚通过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并没有在那里安装模块。

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

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

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

其他回答

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

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

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

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

我喜欢使用ubuntu组来实现这一点,而不是更改所有者。这很简单。

首先使用apt-get安装nodejs和npmsudo apt-get更新和sudo apt-get安装nodejs npm找出登录者,即用户名,运行以下命令在终端中查看哇哦您可以使用一个非常简单的命令查看分配给您的组列表,通常第一个组是您的用户名本身组运行以下命令以允许登录用户访问sudo chmod 777-R/usr/local&&sudo chgrp$(whoami)-R/usr/local更新npm和nodejsnpm安装-g npm

你已经做好了准备,你的用户可以在没有sudo的情况下运行npm命令

您也可以参考此链接https://askubuntu.com/a/1115373/687804

最好的解决方案是由npm文档提供的。


对于Ubuntu,建议的解决方案是选项#2

简要步骤:为全局安装创建目录:mkdir~/.npm全局

配置npm以使用新目录路径:npm配置集前缀“~/.npm全局”npm-config-get-prefix可以帮助您验证前缀是否已更新。结果将是<Your Home Directory>/.npm global

打开或创建~/.profile文件并添加此行:导出PATH=~/.npm全局/bin:$PATH

返回命令行,更新系统变量:源~/.profile

您也可以使用相应的ENV变量代替步骤2-4(例如,如果您不想修改~/.profile):

NPM_CONFIG_PREFIX=~/.NPM全局


对于Mac,建议的解决方案是选项#3

在Mac OS上,您可以使用Homebrew包管理器完全避免此问题

brew安装节点

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

sudo chown -R $USER ~/tmp

没关系!

问题:您(用户)没有正确的目录权限集。

立即的解决方法是使用sudo运行npm安装,但这可能会给您带来同样的错误,或者安装不正确。

而且,更改目录所有权不是一个好选项,只是一个临时补丁。


解决方案/建议:更改npm的默认目录(来自官方文档)

在前进之前备份计算机。

(可选)如果安装错误,请首先卸载:

npm uninstall <package-name>  # use sudo if you used it while installation
npm cache verify  # or, npm cache clean for npm version below 5.x.x 

为全局安装创建目录:mkdir~/.npm全局配置npm以使用新目录路径:npm配置集前缀“~/.npm全局”打开或创建~/.profile或~/.bash_profile文件,然后添加以下行:导出PATH=~/.npm全局/bin:$PATH返回命令行,更新系统变量,或重新启动终端:源~/.profile(可选)测试:在不使用sudo的情况下全局下载包。npm安装-g jshint