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

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

其他回答

我在安装凹槽时遇到了这个问题(https://github.com/twitter/recess)为Bootstrap 3编译CSS。

安装凹槽时:

-npm install recess -g

你需要解锁主目录中的权限,比如Noah说:sudo chown-R`whoami`~/.npm您还需要对node_modules目录的写入权限,如Xilo因此,如果它仍然不起作用,请尝试:sudo chown-R“whoami”/usr/local/lib/node_modules如果仍然看到错误,可能还需要更正/usr/local权限:sudo chown-R“whoami”/usr/local

请注意,如本文所述,如果您在Mac上,/usr/local/实际上不是一个系统目录,因此,这个答案实际上对Mac用户来说非常“安全”。然而,如果您使用的是Linux,请参阅Christopher Will下面的答案,以获得一个多用户友好、系统目录安全(但更复杂)的解决方案。

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

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

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

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

当尝试以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发行版上使用或轻松安装。

关于如何修复带有EACES错误的npm安装权限的官方文档位于https://docs.npmjs.com/getting-started/fixing-npm-permissions.

在OSX上使用.pkg安装程序重新安装节点后,我遇到了这个问题。这里有一些很好的答案,但我还没有看到npmjs.com的链接。

选项1:将权限更改为npm的默认目录

查找npm目录的路径:npm配置获取前缀

对于许多系统,这将是/usr/local。

警告:如果显示的路径仅为/usr,请切换到选项2。

将npm目录的所有者更改为当前用户的名称(您的用户名!):sudo chown-R$(whoami)$(npm配置获取前缀)/{lib/node_modules,bin,share}这将更改npm和其他一些工具(lib/node_modules、bin和share)使用的子文件夹的权限。

选项2:将npm的默认目录更改为另一个目录

有时您不想更改npm使用的默认目录(即/usr)的所有权,因为这可能会导致一些问题,例如,如果您与其他用户共享系统。

相反,您可以将npm配置为完全使用不同的目录。在本例中,这将是主文件夹中的隐藏目录。

为全局安装创建目录:mkdir~/.npm全局配置npm以使用新目录路径:npm配置集前缀“~/.npm全局”打开或创建~/.profile文件并添加此行:导出PATH=~/.npm全局/bin:$PATH返回命令行,更新系统变量:源~/.profile

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

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

打开终端:

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

输入以下命令:

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

注意:这需要您的密码。

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