Homebrew:让你从 Mac 切换到 Linux 更轻松

文章目录
  1. 1. 前言
  2. 2. 为什么要在 Linux 使用 Homebrew 呢?
  3. 3. 开始在 Linux 使用 Homebrew
  4. 4. 命令行工具 Brew
  5. 5. 从 Mac 到 Linux 的一点不足
  6. 6. 备份 Homebrew 的安装记录
    1. 6.1. 在 Mac 和 Linux 同时管理 Brewfile
  7. 7. 使用 Homebrew 管理软件包

前言

不管你是想要更舒服地从 Mac 搬到 Linux,还是不满意常规的 Linux 包管理器,都可以试试 Homebrew。

Homebrew 项目最初是为了给 Mac 用户提供一个非官方的 Linux 式的包管理器。用户很快就爱上了它友好的界面以及帮助性的提示,而且,它已经被移植到 Linux 系统 —— 这看起来像是一个奇怪的命运转折。

一开始,有两个分开的项目分别针对 macOS 和 Linux (Homebrew 与 Linuxbrew),但是现在是由 Homebrew 核心管理着这两个操作系统。由于我正 从 Mac 切换到 Linux,所以一直在研究我在 macOS 最常用的开源软件在 Linux 表现如何,最终,我很高兴地发现 Homebrew 对 Linux 的支持太赞了!

为什么要在 Linux 使用 Homebrew 呢?

长期使用 Linux 的用户对 Homebrew 的第一反应是:“为什么不直接使用……呢”,省略号代表他们喜欢的某个 Linux 包管理器。基于 Debian 的系统早就有了 apt,基于 Fedora 的系统则有 dnfyum,并且像 Flatpak 跟 AppImage 这样的项目,在两种系统上都能流畅运行。我花了不少时间尝试这些技术,不得不说,它们都有其强大之处。

那我为什么还要 坚持使用 Homebrew 呢?首先,我对它非常熟悉。在为我过去使用的专有软件寻找开源替代品的过程中,我已经学会了许多使用方法,而保持一些熟悉的东西,比如 Homebrew,可以让我专注于一次学习一件事情,而不是被不同系统间的差异搞垮。

此外,我没有看到哪一个包管理器像 Homebrew 一样,对用户如此友好。正如默认的帮助命令一样,命令井然有序:

1.  `$ brew -h`
2.  `Example usage:`
3.   `brew search [TEXT|/REGEX/]`
4.   `brew info [FORMULA...]`
5.   `brew install FORMULA...`
6.   `brew update`
7.   `brew upgrade [FORMULA...]`
8.   `brew uninstall FORMULA...`
9.   `brew list [FORMULA...]`

11.  `Troubleshooting:`
12.   `brew config`
13.   `brew doctor`
14.   `brew install --verbose --debug FORMULA`

16.  `Contributing:`
17.   `brew create [URL [--no-fetch]]`
18.   `brew edit [FORMULA...]`

20.  `Further help:`
21.   `brew commands`
22.   `brew help [COMMAND]`
23.   `man brew`
24.   `<https://docs.brew.sh>`

过于简短的输出可能会被误解为它功能局限,但是你简单看看每一个子命令,都有很丰富的功能。虽然上面的列表只有短短 23 行,但对高级用户来说,光是子命令 install 就包含整整 79 行的帮助信息:

1.  `$ brew --help | wc -l`
2.  `23`
3.  `$ brew install --help | wc -l`
4.  `79`

它可以选择忽略或者安装依赖关系,也可以选择用源代码编译以及用什么编译器来编译某个确切的上游 Git 提交,或者选择应用的官方 “灌装” 版。总而言之,Homebrew 即适合新手,也同样能满足老鸟。

开始在 Linux 使用 Homebrew

如果你想要试着使用 Homebrew,可以用这个单行脚本在 Mac 或者 Linux 上进行安装:

1.  `$ /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"`

这条命令会立即开始安装 Homebrew。如果你比较谨慎,可以使用 curl 将该文件下载到本地,检查完毕之后再运行。

1.  `$ curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh --output homebrew_installer.sh`
2.  `$ more homebrew_installer.sh # 审核该脚本,直到你觉得没问题了`
3.  `$ bash homebrew_installer.sh`

对 Linux 的安装步骤还包括如何配置点文件,对于 Debian 系统来说是 ~/.profile,对于 Fedora 系统是 ~/.bash_profile

1.  `$ test -d /home/linuxbrew/.linuxbrew && eval $(/home/linuxbrew/.linuxbrew/bin/brew shellenv)`
2.  `$ test -r ~/.bash_profile && echo "eval \$($(brew --prefix)/bin/brew shellenv)" >>~/.bash_profile`
3.  `$ echo "eval \$($(brew --prefix)/bin/brew shellenv)" >>~/.profile`

为了确认已经安装好,Homebrew 团队提供一个空的 hello “秘方” 供测试:

1.  `$ brew install hello`
2.  `==> Downloading https://linuxbrew.bintray.com/bottles/hello-2.10.x86_64_linux.bottle.tar.gz`
3.  `######################################################################## 100.0%`
4.  `==> Pouring hello-2.10.x86_64_linux.bottle.tar.gz`
5.  `🍺  /home/linuxbrew/.linuxbrew/Cellar/hello/2.10: 52 files, 595.6KB`

看起来安装毫无问题,让我来试试更多操作。

命令行工具 Brew

Homebrew 宣称自己是一款默认只 “安装你需要而 [Linux] 没有的东西”的应用程序。

你可以用 brew 命令安装任何打包在 Homebrew 中的命令行软件。这些包的定义文件叫做 “秘方formula”,而且它们通过“瓶子bottle”来编译并分享。在 Homebrew 的世界里,还有许多 “啤酒方面” 的术语,但这个包管理器主要目的是让软件便于使用。

都有些什么样的软件呢?对我这样的技术玩家(既然你已经在读这篇文章,估计你也是)来说最方便的东西。例如,便利的 tree 命令,可以展示目录结构,或者 pyenv,我用它来 在 Mac 管理不同版本 Python

你可以用 search 命令查看所有可以安装的“秘方”,在后面加上 wc 命令看看一共有多少:

1.  `# -l 选项统计行数`
2.  `$ brew search | wc -l`
3.   `5087`

迄今为止,一共有 5000 多个 “秘方”,这囊括了很多软件。需要注意的是:并非所有 “秘方” 都能在 Linux 运行。在 brew search --help 输出中有一节提到可以按软件运行的操作系统来筛选软件。它会在浏览器打开用于每个操作系统的软件仓库。我运行的是 Fedora,所以我会用它来试一试:

1.  `$ brew search --fedora tree`

浏览器打开了网址 https://apps.fedoraproject.org/packages/s/tree,向我展示了所有 Fedora 的可用选项。你也可以通过其它方法进行浏览。“秘方” 被集中整理到由操作系统划分的核心仓库当中(Mac 在 Homebrew Core,Linux 在 Linux Core)。同样也可以通过 Homebrew API 在网页显示

即使有这些选择,我还是通过其它用户的推荐找到很多新工具。我列出一些我最喜欢的工具,你可以在里面找点灵感:

  • pyenvrbenvnodenv 用来管理(相应的) Python、Ruby 和 Node.js 版本
  • imagemagick 用于脚本化编辑图片
  • pandoc 用于脚本化转换文档格式(我通常将 .docx 文件转成 .md 或者 .html)
  • hub 为 GitHub 用户提供 更好的 Git 体验
  • tldr 展示了命令工具的使用范例

想要深入了解 Homebrew,可以去 trldr 页面 看看,比起应用的 man 页面,它要友好得多。使用 search 命令确认你可以安装:

1.  `$ brew search tldr`
2.  `==> Formulae`
3.  `tldr ✔`

太好了!对勾说明你可以安装。那么继续吧:

1.  `$ brew install tldr`
2.  `==> Downloading https://linuxbrew.bintray.com/bottles/tldr-1.3.0_2.x86_64_linux.bottle.1.tar.gz`
3.  `######################################################################## 100.0%`
4.  `==> Pouring tldr-1.3.0_2.x86_64_linux.bottle.1.tar.gz`
5.  `🍺  /home/linuxbrew/.linuxbrew/Cellar/tldr/1.3.0_2: 6 files, 63.2KB`

Homebrew 提供了编译好的二进制文件,所以你不必在本地机器上从源码编译。这能节省很多时间,也不用听 CPU 风扇的噪声。我很欣赏 Homebrew 的另外一点是,你不完全理解每一个选项的含义也不会影响正常使用。若你想自己编译,可以在 brew install 命令后面加上 -s 或者 --build-from-source 标识,这样就能从源码编译 “秘方”(即便已经有一个 “瓶子” 存在)。

同样,软件底层的复杂性也很有意思。使用 info 可以查看 tldr 软件的依赖管理,“秘方” 的源代码存放在磁盘上的何处,甚至还能查看公开分析。

1.  `$ brew info tldr`
2.  `tldr: stable 1.3.0 (bottled), HEAD`
3.  `Simplified and community-driven man pages`
4.  `https://tldr.sh/`
5.  `Conflicts with:`
6.   ``tealdeer (because both install `tldr` binaries)``
7.  `/home/linuxbrew/.linuxbrew/Cellar/tldr/1.3.0_2 (6 files, 63.2KB) *`
8.   `Poured from bottle on 2020-06-08 at 15:56:15`
9.  `From: https://github.com/Homebrew/linuxbrew-core/blob/master/Formula/tldr.rb`
10.  `==> Dependencies`
11.  `Build: pkg-config ✔`
12.  `Required: libzip ✔, curl ✔`
13.  `==> Options`
14.  `--HEAD`
15.   `Install HEAD version`
16.  `==> Analytics`
17.  `install: 197 (30 days), 647 (90 days), 1,546 (365 days)`
18.  `install-on-request: 197 (30 days), 646 (90 days), 1,546 (365 days)`
19.  `build-error: 0 (30 days)`

从 Mac 到 Linux 的一点不足

在 macOS,Homebrew 的 cask(“酒桶”)子命令可以让用户使用命令行安装、管理整个应用软件。不幸的是,cask还不能在任何 Linux 发行版上使用。我在安装一个开源工具时发现了这点:

1.  `$ brew cask install tusk`
2.  `Error: Installing casks is supported only on macOS`

我在 论坛上 问了一下,很快得到其他用户的反馈。总结一下,方案如下:

  • 复刻 Homebrew 项目,构建这个特性,然后像别人展示其价值
  • 给该软件写一个 “秘方”,然后从源代码编译
  • 为该软件创建一个第三方仓库

最后一个是我最感兴趣的。Homebrew 通过 创建并维护 “水龙头tap” (另一个受啤酒影响的术语)管理第三方仓库。随着你对系统越来越熟悉,并想加入生态系统, “水龙头” 是值得研究的。

备份 Homebrew 的安装记录

我最中意的 Homebrew 特性之一就是你可以像其它任何 用版本控制工具来备份点文件 一样备份你的安装记录。为了实现这个目的,Homebrew 提供 bundle(“捆扎”)子命令,它可以控制一个叫 dump(“倾倒”)的子命令生成一个 Brewfile。这个文件包含你目前所有安装的工具列表,可以重复使用。进入你想使用的目录然后运行命令,它会根据你所安装的软件生成 Brewfile

1.  `$ cd ~/Development/dotfiles # This is my dotfile folder`
2.  `$ brew bundle dump`
3.  `$ ls Brewfile`
4.  `Brewfile`

当我换了一台机器,想要安装一样的软件时,进入含有 Brewfile 的文件夹,然后重新安装:

1.  `$ ls Brewfile`
2.  `Brewfile`
3.  `$ brew bundle`

它会在我的新机器上安装所有列出的 “秘方”。

在 Mac 和 Linux 同时管理 Brewfile

Brewfile 非常适合备份你目前的安装记录,但是如果某些在 Mac 上运行的软件无法运行在 Linux 呢?或者刚好相反?我发现不管是 Mac 还是 Linux,如果软件无法在当前操作系统运行,Homebrew 会优雅地忽略那一行。如果它遇到不兼容的请求(比如使用 brew 在 Linux 安装 “酒桶cask” 时),它会选择跳过,继续安装过程:

1.  `$ brew bundle --file=Brewfile.example`

3.  `Skipping cask licecap (on Linux)`
4.  `Skipping cask macdown (on Linux)`
5.  `Installing fish`
6.  `Homebrew Bundle complete! 1 Brewfile dependency now installed.`

为了保持配置文件的简洁,我在两个操作系统上使用同一份 Brewfile,因为它只安装与操作系统相关的版本,所以我一直没有遇到任何问题。

使用 Homebrew 管理软件包

Homebrew 已经成了我必备的命令行工具,由于我很熟悉它,所以在 Linux 上的体验也充满乐趣。Homebrew 让我的工具井然有序,并且时刻保持更新,我愈发欣赏它在实用性与功能上找到的平衡点。我更喜欢将软件包管理的细节保持在用户需要了解的最小程度,大多数人都会从中受益。如果你已经很熟悉 Linux 包管理器了,Homebrew 可能会让你觉得很基础,但稍微深入一点看,就会发现它的高级选项远远超过本文的内容。

对 Linux 用户来说,他们有很多包管理器可以选择。如果你来自 MacOS,Homebrew 会让你宾至如归。