mac下國內安裝Homebrew教程
Homebrew
是一款包管理工具,目前支援macOS
和linux
系統。主要有四個部分組成:brew
、homebrew-core
、homebrew-cask
、homebrew-bottles
。
名稱 | 說明 |
---|---|
brew | Homebrew 原始碼倉庫 |
homebrew-core | Homebrew 核心源 |
homebrew-cask | 提供 macOS 應用和大型二進位制檔案的安裝 |
homebrew-bottles | 預編譯二進位制軟體包 |
本文主要介紹Homebrew
安裝方式以及如何加速訪問,順便普及一些必要的知識。
1. 指令碼說明
Homebrew
預設安裝指令碼:
/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
如果你等待一段時間之後遇到下面提示,就說明無法訪問官方指令碼地址:
curl: (7) Failed to connect to raw.githubusercontent.com port 443: Operation timed out
請使用下面的指令碼:
/usr/bin/ruby -e "$(curl -fsSL https://cdn.jsdelivr.net/gh/ineo6/homebrew-install/install)"
2. 執行命令
/usr/bin/ruby -e "$(curl -fsSL https://cdn.jsdelivr.net/gh/ineo6/homebrew-install/install)"
如果命令執行中卡在下面資訊:
==> Tapping homebrew/core
Cloning into '/usr/local/Homebrew/Library/Taps/homebrew/homebrew-core'...
請Command + C
中斷指令碼執行如下命令:
cd "$(brew --repo)/Library/Taps/"
mkdir homebrew && cd homebrew
git clone git://mirrors.ustc.edu.cn/homebrew-core.git
成功執行之後繼續執行前文的安裝命令。
最後看到==> Installation successful!
最最後執行:
brew update
cask
同樣也有首次下載緩慢的問題,解決方法大致同上:
cd "$(brew --repo)/Library/Taps/"
cd homebrew
git clone https://mirrors.ustc.edu.cn/homebrew-cask.git
3. 解除安裝Homebrew
使用官方指令碼同樣會遇到uninstall
地址無法訪問問題,可以替換為下面指令碼:
/usr/bin/ruby -e "$(curl -fsSL https://cdn.jsdelivr.net/gh/ineo6/homebrew-install/uninstall)"
4. 設定映象
brew
、homebrew/core
是必備專案,homebrew/cask
、homebrew/bottles
按需設定。
通過brew config
命令檢視配置資訊。
4.1 中科大源
git -C "$(brew --repo)" remote set-url origin https://mirrors.ustc.edu.cn/brew.git
git -C "$(brew --repo homebrew/core)" remote set-url origin https://mirrors.ustc.edu.cn/homebrew-core.git
git -C "$(brew --repo homebrew/cask)" remote set-url origin https://mirrors.ustc.edu.cn/homebrew-cask.git
brew update
# 長期替換homebrew-bottles
echo 'export HOMEBREW_BOTTLE_DOMAIN=https://mirrors.ustc.edu.cn/homebrew-bottles' >> ~/.bash_profile
source ~/.bash_profile
注意bottles
可以臨時設定,在終端執行下面命令:
export HOMEBREW_BOTTLE_DOMAIN=https://mirrors.ustc.edu.cn/homebrew-bottles
4.2 清華大學源
git -C "$(brew --repo)" remote set-url origin https://mirrors.tuna.tsinghua.edu.cn/git/homebrew/brew.git
git -C "$(brew --repo homebrew/core)" remote set-url origin https://mirrors.tuna.tsinghua.edu.cn/git/homebrew/homebrew-core.git
git -C "$(brew --repo homebrew/cask)" remote set-url origin https://mirrors.tuna.tsinghua.edu.cn/git/homebrew/homebrew-cask.git
brew update
# 長期替換homebrew-bottles
echo 'export HOMEBREW_BOTTLE_DOMAIN=https://mirrors.tuna.tsinghua.edu.cn/homebrew-bottles' >> ~/.bash_profile
source ~/.bash_profile
4.3 恢復
git -C "$(brew --repo)" remote set-url origin https://github.com/Homebrew/brew.git
git -C "$(brew --repo homebrew/core)" remote set-url origin https://github.com/Homebrew/homebrew-core.git
git -C "$(brew --repo homebrew/cask)" remote set-url origin https://github.com/Homebrew/homebrew-cask.git
brew update
homebrew-bottles
配置只能手動刪除,將~/.bash_profile
檔案中的HOMEBREW_BOTTLE_DOMAIN=https://mirrors.xxx.com
內容刪除,並執行source ~/.bash_profile
。
5. 其他
5.1 cask
目前cask
是從GitHub
上讀取軟體源,而GitHub Api
對匿名訪問有限制,如果使用比較頻繁的話,可以申請Api Token
,然後在環境變數中配置到HOMEBREW_GITHUB_API_TOKEN
。
在.bash_profile
中追加:
export HOMEBREW_GITHUB_API_TOKEN=yourtoken
注意:因為cask
是基於GitHub
下載軟體,所以目前是無法加速的。
6. 總結
在前面的過程中我們把brew
和homebrew-core
的地址都指向到中科大映象。
原理是通過修改install
指令碼,在裡面預設映象地址來做到的。
#!/usr/bin/ruby
# This script installs to /usr/local only. To install elsewhere (which is
# unsupported) you can untar https://github.com/Homebrew/brew/tarball/master
# anywhere you like.
HOMEBREW_PREFIX = "/usr/local".freeze
HOMEBREW_REPOSITORY = "/usr/local/Homebrew".freeze
HOMEBREW_CACHE = "#{ENV["HOME"]}/Library/Caches/Homebrew".freeze
# 這裡替換了BREW_REPO
BREW_REPO = "https://mirrors.ustc.edu.cn/brew.git".freeze
最後不完美的地方是我們只能預設brew
映象,沒找到比較好的辦法預設homebrew-core
、homebrew-cask
的git
地址。