题 没有sudo的npm抛出错误


我刚刚通过nodejs.org上的软件包安装了node和npm,每当我尝试使用npm搜索或安装某些内容时,它会抛出以下错误,除非我sudo命令。我有一种感觉这是权限问题?我已经是管理员了。

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

1018
2018-04-22 15:35


起源


请考虑 解决方案 运用 NVM: stackoverflow.com/a/24404451/1480391 (而不是通过权限进行黑客攻击) - Yves M.
我也得到了这个错误,我通过安装了Node和NVM Node的包管理器。 - jtheletter
@janaspage您无法通过安装节点或NVM(节点版本管理器) NPM (节点包管理器),这是没有意义的。 NPM位于节点内(它同时安装)。看看维基百科页面: en.wikipedia.org/wiki/Npm_(software) - Yves M.
@YvesM。,不通过NPM(节点打包模块),通过Node 安装包管理器。 - jtheletter
最后一个解决方案比 sudo chown: github.com/sindresorhus/guides/blob/master/... - Dmitri Zaitsev


答案:


这看起来像您的主目录中的权限问题。收回所有权 .npm 目录执行:

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

1867
2018-04-22 16:11



我以为 whoami 是一个占位符,但它的工作原理按字面顺序排列,所以它必须是一个我不理解的变量。 - SimplGy
whoami是一个真正的shell命令 en.wikipedia.org/wiki/Whoami。周围的反击 whoami 确保它正确执行,然后放入chown命令 - Noah
您也可以手动指定用户名。如果您的用户名是“simpleascouldbe”,则命令为 sudo chown -R simpleascouldbe ~/.npm - Noah
npm不要求也不要使用sudo - 请参阅@HeberLZ下面的答案,特别是他的第二个选项:./ configure --prefix = xxxxxx - Scott Stensland
@ChristopherWill:这不会改变系统目录的所有权。这正在改变用户主目录中目录的所有权 应该 由用户拥有。 - user4815162342


安装Node时使用的权限在执行诸如写入内容之类的操作时将是必需的 npm目录 (npm linknpm install -g等)。

您可能使用root权限运行节点安装,这就是全局程序包安装要求您成为root用户的原因。


解决方案1:NVM

不要破解权限,以正确的方式安装节点。

在开发计算机上,您不应该使用root权限安装和运行节点,否则就像这样 npm linknpm install -g 将需要相同的权限。

NVM (节点版本管理器)允许您安装没有root权限的节点,并允许您安装许多版本的节点以便轻松使用它们。完美的开发。

  1. 卸载节点(可能需要root权限)。 这个 可能会帮助你。
  2. 然后安装 NVM 以下说明 在本页
  3. 通过NVM安装节点: nvm install node

现在 npm linknpm install -g 将不再要求你成为root用户。

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


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

不要破解权限,以正确的方式全局安装npm包。

如果您使用的是OSX或Linux,则可以 为您的全局包创建用户专用目录 和设置 npm 和 node 知道如何查找全局安装的包。

查看 这篇好文章 有关在没有sudo的情况下全局安装npm模块的分步说明。

另见:npm的文档 修复npm权限


482
2018-06-25 09:05



在所有解决方案中,NVM解决方案为我提供了最好的结果。强烈建议使用NVM而不是使用权限进行操作。 - wenincode
这些说明非常有效。但是你可能想要 在卸载nodejs之前删除使用sudo安装的模块: npm ls -gp | awk -F/ '/node_modules/ && !/node_modules.*node_modules/ {print $NF}' | xargs npm -g rm  - 我不得不重新安装nodejs并在root shell中卸载它们,否则你将继续使用符号链接到yo,grunt等... - Bruno Flávio
这是最好的解决方案,我先删除了所有模块 sudo npm list -g --depth=0. | awk -F ' ' '{print $2}' | awk -F '@' '{print $1}' | sudo xargs npm remove -g  stackoverflow.com/a/22290968/1449157 然后删除 npm 并通过它安装 nvm - Fabio Antunes
有关节点的卸载说明,请使用此SO答案 stackoverflow.com/a/11178106/480031 - seangates
为什么使用root在生产机器上安装节点是可以的? - Bruno Peres


您还需要写入权限 node_modules 目录:

sudo chown -R $USER /usr/local/lib/node_modules

385
2017-08-24 03:23



以及 ~/tmp 我的目录。 - knownasilya
我不知道为什么这仍然会得到提升。将系统目录的所有权更改为特定用户是一种非常糟糕的做法!请参阅下面的答案了解其他解决方案(例如为节点用户创建单独的组)。 - Christopher Will
这是错的,我摇头 - 0fnt
无论你做什么 - 绝对不要在/ usr / local / lib或/ usr / lib /上运行'sudo chmod -R whoami'你会破坏你的sudoers文件,你会恨自己。 - qodeninja
各位,请恭喜... Then I ran sudo chown -R $USER /* and everything was fine  - 不 - 你毁了你的机器。 - commonpike


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

安装凹槽时:

-npm install recess -g
  1. 您需要解锁您的权限 home 目录,像 诺亚 说:

    sudo chown -R `whoami` ~/.npm
    
  2. 您还需要写入权限 node_modules 目录,像 Xilo 说,如果仍然无法正常工作,请尝试:

    sudo chown -R `whoami` /usr/local/lib/node_modules
    
  3. 如果您仍然看到错误,您可能还需要 正确 /usr/local 权限

    sudo chown -R `whoami` /usr/local
    

请注意,如所示 在这篇文章中  /usr/local/ 如果你在Mac上,它实际上不是系统目录,因此,对于Mac用户来说,这个答案实际上是完全“安全的”。但是,如果您使用的是Linux,请参阅 克里斯托弗威尔以下是一个多用户友好的系统目录安全(但更复杂)解决方案的答案。


57
2017-10-03 23:16



这是一个坏主意。您可能不希望系统目录由特定用户拥有。除了严重的安全问题,这也不是多用户兼容的。 - Christopher Will
是的,但对于开发环境+2来说它是一个很好的解决方案,特别是如果你已经安装了node.js并且只需要继续摇摆! - elliotrock
这实际上对我有用。 :) - IAmAndroid
你真的不应该拥有主目录之外的包 - Ben


更改“系统全局”文件夹上的所有者是一个黑客。在全新安装时,我会将NPM配置为使用已经可写的“用户全局”程序位置:

npm config set prefix ~/npm

然后确保将该文件夹添加到路径中:

export PATH="$PATH:$HOME/npm/bin"

看到 @ErikAndreas回答 至 没有sudo,NPM模块不会全局安装  和 更长的分步指南 通过 @sindresorhus 还有套 $MANPATH


49
2018-05-27 12:36



我非常同意,除非我建议如果你只是设置前缀 $HOME 那么通常你的 .profile 脚本将照顾 $PATH 下次您使用它时(例如下次登录时)。 - Jess Austin
@JessAustin:也许,但它也会给你带来更多的混乱 $HOME 并可能会干扰其他(未来?)NPM文件/子文件夹。更喜欢将来自不同包管理器/语言/构建系统的二进制文件分开并明确设置 $PATH (在登录时间脚本中)代替。 - Joel Purra
呃,杂乱无章?我们刚才谈到全球安装的模块 ~/lib/node_modules,以及相关的CLI(如果存在) ~/bin。对于许多用户来说,特别是如果他们没有root,两者都是 ~/bin 和 ~/lib 已经存在。 - Jess Austin
@JessAustin:这也是图书馆和二进制文件名称冲突的问题。假设您指出NPM将二进制文件放入 ~/bin 然后对一个或两个额外的包管理器执行相同的操作。它可能不会在今天或明天发生,但是存在明显的风险,即来自不同管理器的两个包具有名称冲突并覆盖彼此的文件。对我来说,这是一个足够好的案例,可以有单独的前缀。 (具体的例子将不胜感激。) - Joel Purra
好的,这是可以想象的,但默认行为 npm 更糟糕的是,因为它只是把所有东西都榨干了 /usr/bin。 (提醒Debian中的一个“节点”争议。)我 真 认为默认行为前缀应该是 /usr/local。 Python的 pip 那样做。 - Jess Austin


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

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

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

# 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

仍然需要以root身份安装某些模块(grunt,bower,yo等)。这是因为他们在/ user / bin /中创建了符号链接。

编辑

3年后,我建议使用 节点版本管理器。它为您提供了大量的时间和麻烦。


35
2018-01-09 11:58



如果节点是由源安装的,虽然多用户会有问题,但所有模块都可以在不使用sudo的情况下完美地工作。这也非常重要,因为在yeoman模块的情况下,人们无法通过sudoing yeoman应用程序更新生成器,因为它不允许执行sudo :( - HeberLZ
在Linux上,我通常使用内置的 staff group以授予我的dev文件夹权限。此外,运行是个好主意 chmod g+ws node_modules 确保您的组具有读/写权限。 - jackvsworld
@jackvsworld我不知道工作人员组。我想这将是一个更平滑的解决方案,因为一个人不必创建一个新的虚构组...虽然它不那么明确。但感谢您的投入。 - Christopher Will


官方文件 如何解决 npm install 权限与 EACCES 错误位于 https://docs.npmjs.com/getting-started/fixing-npm-permissions

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

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

  1. 找到npm目录的路径:

    npm config get prefix
    

对于许多系统,这将是 在/ usr /本地

警告:如果显示的路径是正确的 在/ usr, 切换到 选项2

  1. 将npm目录的所有者更改为当前用户的名称(您的用户名!):

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

    这会更改npm和其他一些工具使用的子文件夹的权限(LIB / node_modules箱子,和 分享)。

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

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

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

  1. 为全局安装创建一个目录:

    mkdir ~/.npm-global
    
  2. 配置npm以使用新的目录路径:

    npm config set prefix '~/.npm-global'
    
  3. 打开或创建一个〜/ .profile文件并添加以下行:

    export PATH=~/.npm-global/bin:$PATH
    
  4. 回到命令行,更新系统变量:

    source ~/.profile
    

11
2018-01-23 19:46



谢谢,这个为我工作,因为chown soludion没有。你救了我。 - fmquaglia
如果我得到/ usr,我应该只切换到选项2吗? - user2705620


小心!!!  小心!!!  小心!!! 

chown或chmod是  解决方案,因为安全风险。

而是这样做,做:

如果你打电话,首先检查npm指向的地方:

npm config get prefix

如果返回/ usr,您可以执行以下操作:

mkdir ~/.npm-global
export NPM_CONFIG_PREFIX=~/.npm-global
export PATH=$PATH:~/.npm-global/bin

这会在你的主目录中创建一个npm-Direktory并指向它的npm。

要永久更改此更改,您必须将export-command添加到.bashrc:

echo -e "export NPM_CONFIG_PREFIX=~/.npm-global\nexport PATH=$PATH:~/.npm-global/bin" >> ~/.bashrc

11
2017-12-30 11:18



如果我得到/ usr,我应该只切换到选项2吗? - user2705620
使用它,它的工作原理。 - Someone Special


好像我们需要更多的答案,但无论如何..

Sindre Sorus有一个指南 在OS X和Linux上没有sudo的情况下全局安装npm软件包 概述如何干净安装而不会弄乱权限:

这是一种为给定用户全局安装包的方法。

  1. 为全局包创建目录

    mkdir "${HOME}/.npm-packages"
    
  2. 引用此目录以供将来在.bashrc / .zshrc中使用:

    NPM_PACKAGES="${HOME}/.npm-packages"
    
  3. 指示npm存储全局安装包的位置。在你的 $HOME/.npmrc 文件添加:

    prefix=${HOME}/.npm-packages
    
  4. 确保节点将找到它们。将以下内容添加到.bashrc / .zshrc:

    NODE_PATH="$NPM_PACKAGES/lib/node_modules:$NODE_PATH"
    
  5. 确保您找到已安装的二进制文件和手册页。将以下内容添加到您的 .bashrc/.zshrc

    PATH="$NPM_PACKAGES/bin:$PATH"
    # Unset manpath so we can inherit from /etc/manpath via the `manpath`
    # command
    unset MANPATH # delete if you already modified MANPATH elsewhere in your config
    MANPATH="$NPM_PACKAGES/share/man:$(manpath)"
    

查看 NPM-g_nosudo 自动完成上述步骤

结帐 本指南的来源 了解最新动态。


10
2018-01-20 09:35



tx for edit @AndyHayden :)我在上面的评论中建议我的首选方法:使用NVM! stackoverflow.com/a/24404451/1480391 - ptim
我也是! ..... :) - Andy Hayden
唯一对我有用的解决方案,不涉及权限问题。我讨厌NPM及其愚蠢的权利愚蠢。谢谢你的解决方案! - RyanNerd