我刚刚通过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
在没有sudo的情况下,我在NPM模块上也遇到了类似的问题。问题是,当我安装节点时,我通过chris/lea ppa repo使用sudo进行了安装。
我的解决方案是卸载节点,然后按以下方式安装:
从nodejs.org#下载最新的稳定节点源代码,在我的例子中是node-v0.10.20.tar.gz
tar-zxf node-v0.10.20.tar.gz#解压缩源cd node-v0.10.20#输入未压缩文件夹sudo chown$USER-R/usr/local./configure--prefix=/usr/local&&make&&makeinstall
PD:如果您不想更改/usr/local文件夹的所有权,可以将其安装在您已经拥有的位置。这种方法的问题是,您必须将安装文件夹与bash命令行绑定,以便稍后使用node命令
mkdir~/opt./configure--prefix=~/opt&&make&&makeinstallecho'export PATH=~/opt/bin:${PATH}'>~/.bashrc#或~/.profile或~/.bash _profile或~/.zshenv,具体取决于当前操作系统
使用这两种方法中的任何一种,您都可以在不使用sudo的情况下执行以下操作
npm安装-g模块安装
其他答案是建议将系统目录的所有权或权限更改为特定用户。我强烈反对这样做,这可能会变得非常尴尬,可能会搞乱整个系统!
这里有一种更通用、更安全的方法,也支持多用户。
为节点用户创建新组,并将所需用户添加到此组。然后将依赖于节点的文件/目录的所有权设置为此组。
# 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目录(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权限的文档。
关于如何修复带有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-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}
现在,您可以安全地全局安装任何模块。希望这有帮助!
TL;博士
在运行npm安装以安装全局包时,请始终使用sudo-i或sudo-H。
当您使用npm时,它会将包下载到您的用户主目录。当您以sudo身份运行时,npm会将文件安装到同一目录中,但现在它们归root用户所有。
所以,这是每一个使用过npm的人都会遇到的情况:
使用npm install foo毫无问题地安装一些本地软件包使用sudo install-g foo-cli安装全局软件包,无问题尝试使用npm安装栏安装本地软件包对npm设计者感到沮丧,因为你必须重新创建一个目录
在sudo中使用-i或-H选项时,主目录将是root的主目录。任何全局安装都会将包缓存到/root/.npm,而不是/home/me/.npm中的root拥有的文件。
只要在运行npm安装来安装全局包时始终使用sudo-i或sudo-H,您的npm权限问题就会迎刃而解。
永远。
--问:修复一个已经一团糟的npm的公认答案。
最好的解决方案是由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安装节点
小心!!!小心!!!小心!!!
chown或chmod不是解决方案,因为存在安全风险。
相反,请执行以下操作:
首先检查npm指向的位置,如果您调用:
npm config get prefix
如果返回/usr,则可以执行以下操作:
mkdir ~/.npm-global
export NPM_CONFIG_PREFIX=~/.npm-global
export PATH=$PATH:~/.npm-global/bin
这将在主目录中创建一个npm目录,并将npm指向它。
要使这些更改永久化,必须将export命令添加到.bashrc中:
echo -e "export NPM_CONFIG_PREFIX=~/.npm-global\nexport PATH=\$PATH:~/.npm-global/bin" >> ~/.bashrc
问题:您(用户)没有正确的目录权限集。
立即的解决方法是使用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
我喜欢使用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
当尝试以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发行版上使用或轻松安装。