我刚刚通过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 install-g等)中进行写入等操作时,需要安装Node时使用的权限。

您可能使用root权限运行Node.js安装,这就是为什么全局包安装要求您是root用户。


解决方案1:NVM

不要使用权限进行黑客攻击,以正确的方式安装Node.js。

在开发机器上,您不应该使用root权限安装和运行Node.js,否则像npm link、npm install-g这样的东西将需要相同的权限。

NVM(节点版本管理器)允许您在没有root权限的情况下安装Node.js,还允许您安装许多版本的Node,以便轻松使用它们。。非常适合发展。

卸载节点(可能需要root权限)。这可能会对你有所帮助。然后按照本页上的说明安装NVM。通过NVM:NVM安装节点

现在npm链接,npm install-g将不再要求您是root用户。

编辑:另请参见https://docs.npmjs.com/getting-started/fixing-npm-permissions


解决方案2:为给定用户全局安装软件包

不要使用权限进行黑客攻击,以正确的方式在全球范围内安装npm包。

如果您在OSX或Linux上,可以为全局包创建一个用户专用目录,并设置npm和node以了解如何查找全局安装的包。

查看这篇很棒的文章,了解如何在不使用sudo的情况下全局安装npm模块的分步说明。

另请参阅:npm关于修复npm权限的文档。

其他回答

在npm目录(npm链接、npm install-g等)中进行写入等操作时,需要安装Node时使用的权限。

您可能使用root权限运行Node.js安装,这就是为什么全局包安装要求您是root用户。


解决方案1:NVM

不要使用权限进行黑客攻击,以正确的方式安装Node.js。

在开发机器上,您不应该使用root权限安装和运行Node.js,否则像npm link、npm install-g这样的东西将需要相同的权限。

NVM(节点版本管理器)允许您在没有root权限的情况下安装Node.js,还允许您安装许多版本的Node,以便轻松使用它们。。非常适合发展。

卸载节点(可能需要root权限)。这可能会对你有所帮助。然后按照本页上的说明安装NVM。通过NVM:NVM安装节点

现在npm链接,npm install-g将不再要求您是root用户。

编辑:另请参见https://docs.npmjs.com/getting-started/fixing-npm-permissions


解决方案2:为给定用户全局安装软件包

不要使用权限进行黑客攻击,以正确的方式在全球范围内安装npm包。

如果您在OSX或Linux上,可以为全局包创建一个用户专用目录,并设置npm和node以了解如何查找全局安装的包。

查看这篇很棒的文章,了解如何在不使用sudo的情况下全局安装npm模块的分步说明。

另请参阅:npm关于修复npm权限的文档。

在我的情况下,这是因为~/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发行版上使用或轻松安装。

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

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

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

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

你可以试试这个,在ubuntu和mac上工作

sudo chown -R $(whoami) /usr/local/lib/node_modules