我已经卸载并安装了Homebrew 3次,因为它似乎永远不允许我安装任何东西,因为它在大多数安装结束时拒绝我的权限。
作为一个例子,我将发布我目前面临的这个libjpeg下载场景。
我尝试安装libjpeg并获取:
$ brew install libjpeg
==> Downloading https://downloads.sf.net/project/machomebrew/Bottles/jpeg-8d.mountain_lion.bottle.1.tar.gz
Already downloaded: /Library/Caches/Homebrew/jpeg-8d.mountain_lion.bottle.1.tar.gz
==> Pouring jpeg-8d.mountain_lion.bottle.1.tar.gz
Warning: Could not link jpeg. Unlinking...
Error: The brew link step did not complete successfully
The formula built, but is not symlinked into /usr/local
You can try again using `brew link jpeg'
Error: Permission denied - /usr/local/opt/jpeg
'brew link jpeg'导致
Error: Permission denied - /usr/local/opt/jpeg
这是我的酿酒医生所读的内容
$ brew doctor
Warning: "config" scripts exist outside your system or Homebrew directories.
./configure scripts often look for *-config scripts to determine if
software packages are installed, and what additional flags to use when
compiling and linking.
Having additional scripts in your path can confuse software installed via
Homebrew if the config script overrides a system or Homebrew provided
script of the same name. We found the following "config" scripts:
/Library/Frameworks/Python.framework/Versions/2.7/bin/python-config
/Library/Frameworks/Python.framework/Versions/2.7/bin/python2-config
/Library/Frameworks/Python.framework/Versions/2.7/bin/python2.7-config
Warning: You have unlinked kegs in your Cellar
Leaving kegs unlinked can lead to build-trouble and cause brews that depend on
those kegs to fail to run properly once built. Run brew link on these:
jpeg
这个许可问题一直使得任何事情都无法使用brew,我真的很感激任何建议。
我能够通过在文件夹上使用chown
解决问题:
sudo chown -R "$USER":admin /usr/local
你也(很可能)必须在/Library/Caches/Homebrew
做同样的事情:
sudo chown -R "$USER":admin /Library/Caches/Homebrew
显然我之前使用过sudo
,改变了我对/usr/local
的文件夹权限,从这里开始所有使用brew的安装都证明是成功的。
在我的情况下,/ usr / local / Frameworks甚至不存在,所以我做了:
sudo mkdir /usr/local/Frameworks
sudo chown -R $(whoami) /usr/local/Frameworks
然后一切都按预期工作。
这解决了我的问题。
sudo chown -R "$USER":admin /Users/$USER/Library/Caches/Homebrew
sudo chown -R "$USER":admin /usr/local
我用这些命令解决了我的问题:
sudo mkdir /usr/local/Cellar
sudo mkdir /usr/local/opt
sudo chown -R $(whoami) /usr/local/Cellar
sudo chown -R $(whoami) /usr/local/opt
所有这些建议都可行。在最新版本的brew医生中,提出了更好的建议。
首先 - 通过在命令行中运行它来修复你可能已经由/usr/local
制造的混乱:
sudo chown -R root:wheel /usr/local
然后获取专门为此用户设置的路径的所有权:
sudo chown -R $(whoami) /usr/local/lib /usr/local/sbin /usr/local/var /usr/local/Frameworks /usr/local/lib/pkgconfig /usr/local/share/locale
如果您运行sudo brew update
然后阅读所有会遇到的警告和错误,所有这些信息都可用...
对于多用户Mac,这对我有用:
sudo chown -R $(whoami):admin $(brew --prefix)/*
github上有一个杀手级脚本,用于修复/ usr / local和brew目录上的perms,任何属于'admin'组成员的人都可以访问它们。
https://gist.github.com/jaibeee/9a4ea6aa9d428bc77925
这是一个比选择的答案更好的解决方案,因为如果您将/ usr / local / ___目录称为$ USER,那么您将破坏该机器上任何其他homebrew的管理员用户。
以下是我发布时脚本的内容:
chgrp -R admin /usr/local
chmod -R g+w /usr/local
chgrp -R admin /Library/Caches/Homebrew
chmod -R g+w /Library/Caches/Homebrew
chgrp -R admin /opt/homebrew-cask
chmod -R g+w /opt/homebrew-cask
对我来说,它起作用了
brew doctor
更改权限命令导致另一个错误
chown: /usr/local: Operation not permitted
实际上它很简单,执行这个命令:brew doctor
并且它将告诉您该怎么做,修复权限问题,例如在我的情况下:
这是问题所在:
Warning: The following directories are not writable by your user:
/usr/local/share/man/man5
/usr/local/share/man/man7
这就是解决方案:
You should change the ownership of these directories to your user.
sudo chown -R $(whoami) /usr/local/share/man/man5 /usr/local/share/man/man7
cd /usr/local && sudo chown -R $(whoami) bin etc include lib sbin share var opt Cellar Frameworks
在我的情况下,我在删除和重新安装SaltStack时遇到问题。
运行后:
ls -lah /usr/local/Cellar/salt/
我注意到集团老板是“员工”。 (顺便说一下,我正在运行macOS Mojave版本10.14.3。)工作人员组可能与我的工作场所配置有关,但我真的不知道。无论如何,我保留了这个小组,以防止自己进一步破坏任何东西。
然后我跑了:
sudo chown -R "$USER":staff /usr/local/Cellar/salt/
之后,我成功地使用此命令(而不是root)删除它:
brew uninstall --force salt
对于macOS High Sierra上的用户的新命令,因为chown
上的/usr/local
是不可能的:
sudo chown -R $(whoami) $(brew --prefix)/*
如果您没有最新的Homebrew:我过去通过强制Homebrew以root身份“修复”了这个问题,这只能通过将Homebrew可执行文件的所有权更改为root来完成。在某些时候,他们删除了此功能。
而且我知道他们会发出很多警告说它不应该以root身份运行,但是来吧,否则它不会正常工作。
我尝试了这个页面上的所有内容,最后我使用了这个解决方案:
brew uninstall --force brew-cask; brew untap $tap_name; brew update; brew cleanup; brew cask cleanup;
我的情况类似于OP,但我的问题特别是由于使用brew cask运行sudo,然后让我的密码不正确。在此之后,我遇到了阻止安装的权限。
解决文件夹运行时Brew权限的错误
brew prune
这将解决问题,我们不必chown任何目录。
尝试也执行此命令
sudo chmod + t / tmp
作为像我一样在这里落地的人的第一选择,请按照以下建议你做的事情:
brew doctor
这是最安全的道路,除其他外,它建议我:
sudo chown -R $(whoami) /usr/local
这解决了权限问题。
OP就是这么做的,但显然没有得到上述建议;你可能会,并且从那里开始总是更好,只有在没有帮助的情况下才寻找非常重要的解决方案。
如果你在OSX High Sierra上,那么/usr/local
就不再是chown
了。您可以使用:
sudo chown -R $(whoami) $(brew --prefix)/*
我有这个问题..一个有效的解决方案是将/usr/local
的所有权更改为当前用户而不是root
:
sudo chown -R $(whoami):admin /usr/local
但实际上这不是一个正确的方法。主要是如果您的机器是服务器或多用户。
我的建议是如上所述更改所有权并使用Brew执行任何操作..(更新,安装...等)然后将所有权重置为root,如下所示:
sudo chown -R root:admin /usr/local
多数民众赞成将解决问题,并保持所有权设置正确。
我没有/user/local/Frameworks
文件夹,所以这个修复了它
sudo mkdir -p /usr/local/Frameworks
sudo chown -R $(whoami) /usr/local/Frameworks
第一行创建一个新的Frameworks文件夹供自制(brew)使用。第二行为该文件夹提供当前用户权限,这已足够。
我有OSX High Sierra
来自最高投票的answer的命令对我不起作用。
它有输出:
chown:/ usr / {my_username} dmin:非法用户名
这个命令工作正常(/ usr / local的组已经是admin
):
sudo chown -R $USER /usr/local
如果你想要比毯子chown -R
更有针对性的方法,你可能会发现this fix-homebrew
脚本有用:
#!/bin/sh
[ -e `which brew` ] || {
echo Homebrew doesn\'t appear to be installed.
exit -1
}
BREW_ROOT="`dirname $(dirname $(which brew))`"
BREW_GROUP=admin
BREW_DIRS=".git bin sbin Library Cellar share etc lib opt CONTRIBUTING.md README.md SUPPORTERS.md"
echo "This script will recursively update the group on the following paths"
echo "to the '${BREW_GROUP}' group and make them group writable:"
echo ""
for dir in $BREW_DIRS ; do {
[ -e "$BREW_ROOT/$dir" ] && echo " $BREW_ROOT/$dir "
} ; done
echo ""
echo "It will also stash (and clean) any changes that are currently in the homebrew repo, so that you have a fresh blank-slate."
echo ""
read -p 'Press any key to continue or CTRL-C to abort.'
echo "You may be asked below for your login password."
echo ""
# Non-recursively update the root brew path.
echo Updating "$BREW_ROOT" . . .
sudo chgrp "$BREW_GROUP" "$BREW_ROOT"
sudo chmod g+w "$BREW_ROOT"
# Recursively update the other paths.
for dir in $BREW_DIRS ; do {
[ -e "$BREW_ROOT/$dir" ] && (
echo Recursively updating "$BREW_ROOT/$dir" . . .
sudo chmod -R g+w "$BREW_ROOT/$dir"
sudo chgrp -R "$BREW_GROUP" "$BREW_ROOT/$dir"
)
} ; done
# Non-distructively move any git crud out of the way
echo Stashing changes in "$BREW_ROOT" . . .
cd $BREW_ROOT
git add .
git stash
git clean -d -f Library
echo Finished.
它不会向您的用户执行chmod
,而是为admin
组(您可能属于该组)提供对自制软件使用的/usr/local
中特定目录的写访问权。它还会在完成之前准确地告诉您它打算做什么。
我不想使用文件夹权限,所以我做了以下事情:
brew doctor
brew upgrade
brew cleanup
然后我能够继续成功安装我的其他酿造配方。