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

当前回答

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

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

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

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

其他回答

这看起来像是主目录中的权限问题。要收回.npm目录的所有权,请执行以下操作:

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

问题:您无权写入npm用于存储全局包和命令的目录。

解决方案:允许npm的权限。

打开终端:

命令+空格键,然后键入“terminal”

输入以下命令:

sudo chown -R $(whoami) $(npm config get prefix)/{lib/node_modules,bin,share}

注意:这需要您的密码。

这个解决方案只允许访问所需的目录,保持其他目录的整洁和安全。

在我看来,最好的选项是npm文档中建议的选项,即首先通过运行npm-config-get-prefix检查全局node_module的默认安装位置。如果像我在Trusty/usr上所做的那样,您可能希望将其更改为一个可以安全拥有的文件夹,而不会像我那样弄乱事情。

为此,请在系统中选择或创建一个新文件夹。为了保持一致性,您可能希望将其放在主目录中,或者像我一样放在/usr/local下,因为我也是Mac用户(我不需要根据我恰好在前面的机器查看不同的位置)。这样做的另一个很好的原因是,/usr/local文件夹可能已经在您的PATH中(除非您想乱用PATH),但新创建的文件夹可能不在其中,您需要自己在.bash配置文件或.bashrc文件中将其添加到PATH中。

长话短说,我使用npm config设置前缀“/usr/local”更改了全局模块的默认位置,创建了/usr/local/lib/node_modules文件夹(它将由npm使用),并使用以下命令更改了npm使用的文件夹的权限:

sudo chown -R $(whoami) $(npm config get prefix)/{lib/node_modules,bin,share}

现在,您可以安全地全局安装任何模块。希望这有帮助!

简单地尝试

npm rebuild

然后在完成后运行通常的命令

sudo chown -R `whoami` /usr/local/lib