共计 6095 个字符,预计需要花费 16 分钟才能阅读完成。
前言
本来想着 macOS 使用 Homebrew 对大家没啥难度,之前就分享了一篇介绍 homebrew-bundle 备份恢复的文章,不过长期使用后还是觉得有必要做一下总结,道理也很简单,越简单越频繁使用的产品就越值得挖掘一些背自己忽视的小技巧,因为如果可以做到每天节省 5 分钟那么量变可能会成为质变。
更新历史
2019 年 09 月 11 日 – 更新转载 Homebrew 深度应用
2019 年 09 月 08 日 – 初稿
阅读原文 – https://wsgzao.github.io/post…
扩展阅读
Homebrew
macOS 使用 homebrew-bundle 优雅的备份和恢复软件列表
Homebrew 简介
Homebrew 是一款享有盛名的包管理工具,是 macOS 上包管理的事实 (de facto) 标准。Homebrew 的意思是家酿啤酒。
它的官方 slogan 是 The missing package manager for macOS (or Linux)。Linuxbrew 已经在 Homebrew 1.9 正式合入,成为 Homebrew 的“一等公民”。
Homebrew 最早的创建者是 Max Howell,目前的主要维护者是 Mike McQuaid。同 Jekyll 等开源项目一样,Homebrew 的核心维护者也是 GitHub 的员工。GitHub 对于员工亲自参加开源项目方面,做得一直不错。
顺带插播一条奇闻逸事:Homebrew 的创始人 Max Howell 活跃在开源社区,目前主要从事 Swift 相关的库开发。他在 2015 年初曾去 Google 面试,因为“白板”写算法题「翻转二叉树」失败,愤而发 tweet 讽刺:
Google: 90% of our engineers use the software you wrote (Homebrew), but you can’t invert a binary tree on a whiteboard so fuck off.
为什么需要 Homebrew
对于使用 Unix/Linux 类系统的用户往往都遇到过这些需求:
- 开源程序是源码分发,需要自己编译,但
./configure
参数超多,还要解决各种库的依赖 - 想把软件安装到用户目录,而不是系统目录(这样不需要 root 权限)
- 自己编译安装了软件,想删除时却不知道在哪里删除和删除哪些文件
各 Linux 发行版为了提升安装软件的体验,大多都提供了官方的包管理器,如 Ubuntu 的 aptitude (apt-get)。而苹果官方没有为 macOS 提供包管理器,市面上最好的解决方案就是 Homebrew。
目前 Homebrew 的中文内容大多以简单入门级教程为主,对于它的各类能力提之甚少,我希望在这里更全面的分享 Homebrew。
Homebrew 快速入门
网上基础的教程很多,我这里只简略的介绍下。对于基础功能类的深度用法,推荐这篇 macOS 包管理工具 Homebrew 不完全指南。
Homebrew 安装
安装
开始安装前需要安装 macOS 命令行工具:
xcode-select —install
或者,在 https://developer.apple.com/d… 下载安装。
然后执行:
/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
基础功能
# 安装 | |
brew install wget | |
# 完成安装后可以列出已安装内容 | |
brew list | |
# 显示可以升级的包 | |
brew outdated | |
cmake (3.13.4) < 3.14.0 | |
yarn (1.13.0) < 1.15.2 | |
youtube-dl (2019.03.09) < 2019.03.18 | |
# 进行升级 | |
brew upgrade cmake | |
# 删除 | |
brew uninstall wget | |
# 安装桌面程序 | |
brew cask install google-chrome |
对于 Homebrew-cask 管理桌面程序,这里先不细说,后面会专门讲。
Homebrew 会把软件安装到 /usr/local/Cellar
,并且通过软链链接到 /usr/local/bin
。我们可以通过 brew unlink
和 brew link
删除或创建链接。
名词解释
Homebrew 把软件安装过程中的各种名词都进行了拟物化命名,这些命名挺有意思,但对于大多数英语水平一般的人来说,有不少词汇有些生僻。
英文 | 直译 | 实际含义 |
---|---|---|
formula(e) | 公式 | 安装包的描述文件,formulae 为复数 |
cellar | 地窖 | 安装好后所在的目录 |
keg | 小桶 | 具体某个包所在的目录,keg 是 cellar 的子目录 |
bottle | 瓶子 | 预先编译好的包,不需要现场下载编译源码,速度会快很多;官方库中的包大多都是通过 bottle 方式安装 |
tap | (插入) 水龙头 | 下载启用某个源 |
cask | 木桶 | 安装 macOS native 应用的扩展 |
bundle | 捆 | 描述 Homebrew 依赖的扩展 |
Homebrew 进阶用法
对于 Homebrew,我们很多时候往往都是上来就 brew search
或是 brew install
。缺什么安什么,没有充分的应用它的强大能力。
首先,Homebrew 虽为解决控制台程序而生,但它完全有能力(Cask)安装任何桌面软件。它还支持丰富的分类目软件库或第三方库。
除此之外,它还有一个打包安装或备份工具,可以把已安装的软件输出成 Brewfile。迁移到新电脑时,只要根据 Brewfile 运行 Homebrew bundle,就可以一键安装全部控制台、桌面和来自 Mac App Store 的程序(Mac App Store 上的软件通过 mas 支持)。
Tap
Tap 在 Homebrew 中我理解是个动词,指的是启用某个源。实际看了下发现,homebrew-services 和 homebrew-bundle 也已 tap 形式存在,因此可以认为 tap 实际指的应该是扩展(extension)。
Homebrew 默认情况下会自带:
- homebrew/core
- homebrew/cask
- homebrew/services
- homebrew/bundle
后两者并没有任何公式配方,而只是扩展程序。
除此之外的源,需要通过 brew tap
来启用。如:
brew tap heroku/brew | |
brew install heroku |
Services
Homebrew-services 是 Homebrew 的后台服务程序扩展,它基于 macOS 的 launchctl
。后台服务类程序的安装依旧使用 Homebrew,在管理时可以使用 Homebrew-services 进行启动、重启和停止等操作。
brew install mysql | |
brew services start mysql |
Cask
Homebrew-cask 是 Homebrew 的 macOS Native 应用扩展,通过 cask 可以安装各类应用程序。
搜索 Cask 的方法和搜索普通包一样,但安装时需要加上 cask 指令:
brew search google-chrome | |
brew cask install google-chrome |
cask-versions
Homebrew Cask 和 Homebrew 一样,默认库只维护最新版本,但有的时候我们还是需要用旧版的(比如:我只有 Dash 3 的 License,所以需要用 Dash 3 而不是最新的 Dash 4),那就可能需要使用 cask-versions。
brew tap homebrew/cask-versions | |
brew cask install dash3 |
cask-fonts
Homebrew 官方的字体源,比如 Mozilla 的开源字体 Fira Code:
brew tap homebrew/cask-fonts | |
brew cask install font-fira-code |
Bundle
Homebrew 不仅仅是一个包管理器,还具有软件依赖管理能力。通过 Homebrew Bundle 可以帮你解决所有软件依赖,包括官方和第三方的 formula 以及 cask,甚至还包括 Mac App Store(简称 mas)中的应用。
Homebrew 默认就安装了 Homebrew Bundle。
我们只需要一个 Brewfile
,就可以配置好所有需要的应用。熟悉 Ruby 的人应该不太需要解释,毕竟 Ruby 自己就有 Bundler 这套东西,Brewfile 和 Gemfile 属于对应关系。
如果你的安装列表已经足够“干净”,那么可以执行 brew bundle dump
来生成现有依赖,输出到 Brewfile
:
brew bundle dump | |
cat Brewfile | |
brew "git" | |
brew "wget" | |
brew "mas" | |
brew "p7zip" | |
... |
如果想自己写也比较容易,Brewfile
是一种简单的 Ruby DSL,写起来比大部分配置文件都简单。只需要掌握一些常用到的命令,主要有 brew
, tap
, cask
和 mas
。
这四条命令分别对应:
- brew install
- brew tap
- brew cask install
- mas install
注:Homebrew 虽然好用,但 Homebrew 并不能管理 MAS「Mac App Store」上的应用软件,在终端上轻松管理「Mac App Store」中应用的神器 mas-cli
命令行类应用:
brew "git" | |
brew "wget" | |
brew "vim" |
非命令行类:
cask "google-chrome" | |
cask "alfred" | |
cask "visual-studio-code" |
非官方 Formula 应用:
tap "homebrew/cask-versions" | |
brew "dash3" | |
tap "homebrew/cask-fonts" | |
cask "font-source-code-pro" |
Mac App Store 上的应用:
mas "WeChat", id: 836500024
因此,维护好 Brewfile 就可以完美解决应用自动化安装,只需要运行:
brew bundle
Homebrew 扩展用法
提交 Formula
创建并提交一个 Formula 比较容易,官方教程非常详细。这里,我就不做单独介绍了。
自建 Tap
Homebrew 除了各种官方维护的源外,还支持自建软件库。默认使用 GitHub,需要以“homebrew-xxx”格式命名 Repo。Formula 或 Cask 文件需要存放在 Formula 或 Casks 二级目录中。
比如,Heroku 的自建库在 GitHub 上是 heroku/homebrew-brew
。通过 brew tap heroku/brew
就可以获取库里维护的包了。
私有 Tap
上面说到,Tap 默认维护在 GitHub,那么当我们想安装一些需要 保密 的软件时该怎么办呢?
答案是 Tap 支持指定 Git,因此也可以使用内网域名内的 Git:
brew tap yourcompany/brew git@git.yourcompany.com: yourcompany/homebrew-brew.git | |
brew install inhouse-app |
Homebrew Tips
禁用自动升级
Homebrew 自动升级触发概率很高,由于网络等问题,检查更新会很久有时会比较烦。可以通过环境变量禁用自动升级:
HOMEBREW_NO_AUTO_UPDATE=1 brew info mysql
直接安装 Formula
Homebrew 的安装指令并非只支持名字,也可以用文件安装包括网络文件和本地文件。
# 本地 | |
brew install blabla.rb | |
# 远程 | |
brew install https://blablablabla.com/blabla.rb |
安装旧版软件
Homebrew 默认情况下只支持最新版软件安装,有些重要的版本会单独存在。但想安装一些小版本就得自己 DIY 了。
我所知有两种方法:
- 在 GitHub 找到 Formula 所在 Repo 中(默认为 homebrew-core)的文件,把文件远程地址复制下来,用
brew install
安装。 - 进入 homebrew-core 在 macOS 本地的路径,默认为
/usr/local/Homebrew/Library/Taps/homebrew/homebrew-core
,git checkout
到所在 commit,再用brew pin
锁定这个文件的更新,然后进行安装。
Homebrew 常见问题
我遇到的问题大多数是升级 macOS Mojave 之后产生的,升级前要三思而后行,先备份,先备份,先备份
Homebrew Permissions Denied Issues Solution
sudo chown -R $(whoami) $(brew --prefix)/* | |
Reference – https://gist.github.com/iraza…
xcrun: error: invalid active developer path (/Library/Developer/CommandLineTools), missing xcrun at: /Library/Developer/CommandLineTools/usr/bin/xcrun.
Reference – https://apple.stackexchange.c…
# The problem is that you are using XCode and you explicit have to agree to the license agreement. So open Terminal, and run the following: | |
xcode-select --install | |
# This will download and install xcode developer tools and fix the problem. As a follow on step, you may need to reset the path to Xcode if you have several versions or want the command line tools to run without Xcode. | |
xcode-select --switch /Applications/Xcode.app | |
xcode-select --switch /Library/Developer/CommandLineTools |
Homebrew 国内加速镜像
Homebrew 清华大学镜像使用帮助
加速一切 – 配置国内镜像 – Linux apt/macOS brew/Docker/Python Conda/Maven
参考文章
Max Howell on Twitter:“Google: 90% of our engineers use the software you wrote (Homebrew), but you can’t invert a binary tree on a whiteboard so fuck off.”
https://github.com/Linuxbrew/brew/issues/612
Formula Cookbook — Homebrew Documentation
Glossary of Homebrew Terms
Formula Cookbook — Homebrew Documentation
在终端上轻松管理「Mac App Store」中应用的神器 mas-cli
Homebrew 深度应用