Mac M1ARM 和 X86 版 Homebrew 的共存问题


引言

在这里插入图片描述

Homebrew是MacOS平台下最实用的软件包管理工具,拥有安装、卸载、更新、查看、搜索等很多实用的功能。简单的一条指令,就可以实现包管理,而不用你关心各种依赖和文件路径的情况,十分方便快捷。

截至发文,Homebrew 还没有完成M1芯片的原生适配。但目前在新 Mac 上仍然是可用的,并且已经发布了原生支持 ARM 架构的实验性版本。

在不同路径分别安装针对 X86 和 ARM 架构的两个 Homebrew 版本;
优先使用 ARM 版 Homebrew 安装软件包,用 X86 版 Homebrew 安装尚未支持新平台的命令行软件;
使用 Homebrew Bundle 功能从旧 Mac 或 X86 版 Homebrew 迁移软件包。
后文将展开说明具体步骤。由于 ARM 版 Homebrew 仍然处于早期开发阶段,且我对终端环境下系统管理的了解相对粗浅,文章内容难免存在过时或不准确之处,请不吝指正。

1. 安装 ARM 版 Homebrew

根据官方规划,ARM 版 Homebrew 必须安装在 /opt/homebrew 路径下,而非此前的 /usr/local/Homebrew。由于官方的安装脚本还未更新,可以通过如下命令手动安装:

cd /opt # 切换到 /opt 目录
mkdir homebrew # 创建 homebrew 目录
curl -L https://github.com/Homebrew/brew/tarball/master | tar xz --strip 1 -C homebrew
(注: 如果安装和使用过程中报错,可能是因为当前用户对于 /opt/homebrew 路径没有权限。对此,可以通过 sudo chown -R $(whoami) /opt/homebrew 接管该目录。)

虽然上面的步骤已经安装了 ARM 版 Homebrew,但此时在终端中运行 brew 命令并不能直接启动该版本。这是因为默认情况下,ARM 版 Homebrew 用来安装程序的路径 /opt/homebrew/bin 并不在环境变量 PATH 中,因此终端无法检索到该路径下的 brew 程序。

为此,编辑配置文件 ~/.zshrc,加入如下内容:

path=(’/opt/homebrew/bin’ $path)
export PATH
(注: 本文推定读者使用 macOS Big Sur 的默认终端 zsh,如使用 bash 或 fish,则修改 ~/.bashrc 或 ~/.config/fish/config.fish,后同。)

然后重新启动终端。这样,直接执行 brew 就可以启动 ARM 版的 Homebrew 了。

跑题:为什么 ARM 版 Mac 要使用 /opt 路径?
根据《文件系统层次结构标准》(Filesystem Hierarchy Standard,主要为 Linux 系统制定,但对具有共同 UNIX 基因的 macOS 也有参考价值):

/usr/local 目录用于系统管理员在本地安装软件。系统软件更新时,该目录应免于被覆盖。
/opt 目录留作附加应用程序(add-on application)软件包的安装。安装在该目录下的软件包必须将其静态文件放置在单独的 /opt/ 或 /opt/ 路径下。
历史上,/usr/local 主要用于放置在本地编译并另行安装的程序,避免和 /usr 下的系统自带版本冲突;而 /opt 则用于安装非系统自带的、第三方预先编译并发行的独立软件包。

显然,在如今的 macOS 使用场景下,用户很少会需要自行编译软件包,/usr/local 和 /opt 的区分一定程度上已经成为名义上的了。Homebrew 启用 /opt 作为 ARM 版的安装路径,可能更多是出于确保与 X86 版相互区隔的考虑。

2. 安装 X86 版 Homebrew

如上所述,由于很多软件包目前还没有适配 ARM 架构(可以在 Homebrew 的 Apple silicon issue 页面查询),无法通过 ARM 版 Homebrew 安装,因此我们还需要安装一份 X86 版的 Homebrew 备用。

X86 版 Homebrew 无法在 ARM 环境下安装。为此,需要先启动一个 X86 环境的终端。网络上传播较广的方法是创建一个 Terminal.app 的副本,然后令其在 Rosetta 兼容模式下运行,显得有些麻烦。

其实,注意到在任何命令前增加 arch -x86_64,就可以以 X86 模式运行该命令。因此,运行:

arch -x86_64 $SHELL
就可以启动一个 X86 模式终端,使得之后运行的命令都在 X86 模式下运行。

此时,运行 Homebrew 的官方安装脚本

/bin/bash -c “$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)”
就可以完成 X86 版 Homebrew 的安装。

3. ARM 和 X86 版 Homebrew 的共存问题

经过上面的步骤,系统中目前有了两个 brew 程序,即 X86 版的 /usr/local/bin/brew 和 ARM 版的 /opt/homebrew/bin/brew。那么,当在终端中执行 brew 命令时,系统会以哪个为准呢?

当存在重名程序时,终端会按照重名程序在环境变量 PATH 中的先后顺序选择要执行的版本。由于之前配置 ~/.zshrc 时,将 ARM 版 Homebrew 的路径放在了 PATH 的最前面,因此执行 brew 时,位于 /opt/homebrew/bin/brew 的 ARM 版将被优先运行。如果要运行 X86 版,则需要手动输入完整路径 arch -x86_64 /usr/local/bin/brew。

如果觉得输入这么长的命令过于麻烦,可以在 ~/.zshrc 中为两个版本分别设置简称(alias):

abrew=’/opt/homebrew/bin/brew’ # ARM Homebrew
ibrew=‘arch -x86_64 /usr/local/bin/brew’ # X86 Homebrew
这样,执行 abrew install 就可以调用 ARM 版 Homebrew 安装软件包,执行 ibrew install 就可以调用 X86 版,从而不容易混淆。

至于应该使用哪个版本的 Homebrew 安装软件包,需要区别考虑:

对于命令行(CLI)程序:可以优先尝试使用 ARM 版 Homebrew 安装,保证获得针对新架构编译的版本,实现最佳的运行效果。但注意:
有的软件包已经兼容新架构、但还没有发布相应的编译版,需要安装的过程中在本地编译,耗时会相对很长;
如果软件包还没有兼容新架构,使用 ARM 版 Homebrew 安装会报错,此时可以换用 X86 版 Homebrew 安装。
对于图形界面(GUI)程序,即通过 Homebrew Cask 安装的 .app 程序:对于这类软件,Homebrew 起的作用只是从官方渠道下载这些软件的安装包,然后安装到 /Applications 路径(及执行安装脚本,如果有)。因此无论其是否针对新架构优化,通过任一版本 Homebrew 都可以安装。考虑到日后维护方便,建议直接用 ARM 版 Homebrew 安装即可。

参考教程:
https://sspai.com/post/63935

<think>好的,用户现在想了解如何查看Homebrew本。首先,我需要回顾之前的对话历史。用户之前遇到了Homebrew API下载失败的问题,我提供了详细的解决方案,包括更换镜像源配置环境变量。现在用户的问题更基础,可能他们刚解决完安装或配置问题,想确认当前Homebrew本是否最新,或者需要本信息来进一步调试。 用户可能的需求是什么?可能他们在按照某些教程操作时,步骤中需要特定本的Homebrew,或者他们想确保自己安装Homebrew是最新的,以避免兼容性问题。也有可能他们在遇到其他问题时,被建议检查本以确认是否符合要求。 接下来,我需要确定查看Homebrew本的命令。Homebrew通常使用`brew --version`来显示本信息,同时也会显示相关的组件如Homebrew CoreCask的本。此外,单独查看Homebrew CoreCask的本可能需要进入各自的仓库目录,使用git命令查看提交哈希或标签。 是否需要提供多种方法?比如除了基本命令,还有其他的检查方式,比如查看git日志或配置文件。但通常用户只需要简单的命令即可,所以应该优先给出最直接的方法,再视情况补充其他方法。 还要考虑用户的环境是否可能有多个Homebrew安装,比如在M1 Mac上同时安装ARMx86本的Homebrew。这时候可能需要提醒用户注意当前Shell的环境,使用`arch`命令确认架构,或者使用`which brew`查看路径,确保他们检查的是正确安装本。 另外,用户可能会在运行命令后得到一些错误提示,比如如果Homebrew未正确安装,`brew --version`可能不工作。这时候是否需要提供故障排除步骤?比如建议重新安装Homebrew,或者检查PATH环境变量。不过用户当前的问题只是查看本,可能不需要深入解决安装问题,除非他们遇到错误。 总结回答的结构:先给出直接命令,解释输出内容,然后提供其他相关命令(如单独查看CoreCask本),最后补充注意事项,比如多本环境下的检查方法。这样用户可以根据需要选择不同的方法,同时避免常见误区。 还需要注意使用中文,保持回答清晰,步骤明确。确保命令格式正确,用户可以直接复制粘贴到终端执行。如果有必要,解释每个步骤的作用,帮助用户理解背后的原理,比如为什么查看Core本需要进入特定目录。</think>--- ### **查看 Homebrew 本的 3 种方法** --- #### **1. 基础命令(推荐)** 直接在终端执行: ```bash brew --version ``` **输出示例**: ``` Homebrew 4.1.2 Homebrew/homebrew-core (git revision 2a1b5d3; last commit 2024-03-15) Homebrew/homebrew-cask (git revision 8f7e4a; last commit 2024-03-14) ``` - **第一行**:主程序- **第二行**:核心公式库 (`homebrew-core`) 的 Git 提交哈希日期 - **第三行**:Cask 软件库 (`homebrew-cask`) 的 Git 提交信息 --- #### **2. 单独查看组件本** - **Homebrew Core 本**: ```bash cd $(brew --repository homebrew/core) && git log -1 --pretty=format:"%h - %cd" ``` _输出示例_:`2a1b5d3 - Fri Mar 15 10:00:00 2024 +0800` - **Homebrew Cask 本**: ```bash cd $(brew --repository homebrew/cask) && git log -1 --pretty=format:"%h - %cd" ``` --- #### **3. 高级:检查多本冲突(Apple Silicon 设备专用)** 若同时安装了 **ARM ** **x86 ** Homebrew(通过 Rosetta): ```bash # 查看当前 Shell 架构下的 Homebrew 路径 which brew # 强制检查 ARM 本(M1/M2 原生) arch -arm64 /opt/homebrew/bin/brew --version # 检查 x86 本(Intel 兼容模式) arch -x86_64 /usr/local/bin/brew --version ``` --- ### **本信息解读指南** | 字段 | 含义 | 用途 | |------|------|------| | `4.1.2` | 主程序语义化本 | 判断是否需要升级 (`brew update`) | | `git revision` | 公式库最新提交哈希 | 确认仓库是否同步 | | `last commit` | 最后更新时间 | 检测镜像源延迟 | --- ### **常见问题处理** - **报错 `command not found: brew`**: - Homebrew安装 → 参考[安装指南](https://brew.sh/index_zh-cn) - PATH 环境变量未配置 → 在 Shell 配置文件添加: ```bash echo 'export PATH="/opt/homebrew/bin:$PATH"' >> ~/.zshrc source ~/.zshrc ``` - **本号显示 `N/A`**: 运行 `brew update-reset` 强制刷新仓库 --- ### **本管理技巧** - 锁定本(禁止自动更新): ```bash export HOMEBREW_NO_AUTO_UPDATE=1 ``` - 查看更新日志: ```bash brew log ``` --- 通过以上方法,您可以快速定位 Homebrew本状态,并解决多共存环境下的兼容性问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值