Mac终端执行`brew doctor`报`openssl@1.1`警告

发现问题

Mac(M1)终端安装HomeBrew后,执行brew doctor报警告:

zsh 复制代码
lndu@iMac ~ % brew doctor

Please note that these warnings are just used to help the Homebrew maintainers

with debugging if you file an issue. If everything you use Homebrew for is

working fine: please don't worry or file an issue; just ignore this. Thanks!

  


Warning: Some installed formulae are deprecated or disabled.

You should find replacements for the following formulae:

  openssl@1.1
lndu@iMac ~ %

分析上述警告信息,Homebrew 提示 openssl@1.1 被弃用或禁用,主要是因为 macOS 系统自身已经提供了 LibreSSL,而 Homebrew 的 openssl@1.1 是"keg-only"的,这意味着它不会被默认链接到系统路径中以避免冲突。

使用已弃用的软件包,暂时可能不影响使用,但从长期来看,存在安全风险或兼容性问题,还是有必要升级一下openssl版本。

PS:弃用库的原因通常有:

  • 上游项目不再维护
  • 存在未修复的安全漏洞,例如 CVE
  • 发布了新版本,例如opensslopenssl@3
  • 有了更好的替代方案

解决问题

整体思路是:优先迁移到新的openssl版本,如果暂时无法迁移(例如需要使用依赖openssl@1.1的特定库),作为临时方案,为旧版本设置正确的环境变量。

【长期方案】升级openssl版本

Step0 检查依赖关系

通过下面命令,找出依赖于openssl@1.1的库,并记录下来,后面可能需要重新安装它们。

zsh 复制代码
brew deps --tree openssl@1.1
Step1 搜索新版本
zsh 复制代码
brew search openssl
Setp2 安装新版本

选择一个新版本安装,例如

zsh 复制代码
brew install openssl

zsh 复制代码
brew install openssl@3.0
Setp3 重新安装依赖软件

还记得Step0中记录下来的那些依赖软件吗?重新安装它们,HomeBrew通常会尝试自动为她们使用最新的依赖关系。

zsh 复制代码
brew install ca-certificates
Step4 完成✅

最后别忘了再运行一下HomeBrew检查脚本

zsh 复制代码
brew doctor

【临时方案】设置环境变量

为了确保使用 openssl@1.1 的软件能找到它(因为"keg-only"),需要手动在 shell 配置文件(如 ~/.zshrc)中设置相关环境变量。

Step0 设置环境变量

针对 Apple Silicon Mac,依次执行:

zsh 复制代码
export PATH="/opt/homebrew/opt/openssl@1.1/bin:$PATH" # 将 OpenSSL 1.1 的二进制文件加入 PATH
export LDFLAGS="-L/opt/homebrew/opt/openssl@1.1/lib" # 链接器查找库的路径
export CPPFLAGS="-I/opt/homebrew/opt/openssl@1.1/include" # 编译器查找头文件的路径
export PKG_CONFIG_PATH="/opt/homebrew/opt/openssl@1.1/lib/pkgconfig" # pkg-config 查找 .pc 文件的路径

针对 Intel Mac ,对应的路径通常为 /usr/local/opt/openssl@1.1

Step1 加载使配置生效
zsh 复制代码
source ~/.zshrc

最终目标:卸载openssl@1.1

当确定所有软件都不再依赖 openssl@1.1 后,卸载它以消除brew doctor检查的警告。

zsh 复制代码
brew uninstall openssl@1.1
相关推荐
wangbing112510 小时前
_MACOSX目录是什么
mac
怎么没有名字注册了啊1 天前
Apple 编年史
mac·apple
爱玫瑰的小王子3 天前
Window 转 Mac 不痛指南😁
mac
『昊纸』℃3 天前
Mac上编译C语言的简易方法
c语言·mac·教程·xcode·编译
shughui4 天前
2026最新JDK版本选择及下载安装详细图文教程【windows、mac附安装包】
java·linux·开发语言·windows·jdk·mac
LCG元5 天前
STM32嵌入式开发:基于LD3320的智能语音识别系统
stm32·语音识别·xcode
一直会游泳的小猫5 天前
homebrew
linux·mac·工具·包管理
ZZH_AI项目交付5 天前
扫脸功能交给 SDK 后,主工程里的旧代码怎么删除
ios·app·apple
茶底世界之下5 天前
诡异!String 参数在闭包里变成了 <uninitialized>,我排查了整整两天
ios·xcode·swift
星辰即远方6 天前
UITableView操作拓展
macos·ios·xcode