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
相关推荐
权咚20 小时前
阿权的开发经验小集
git·ios·xcode
iOS阿玮1 天前
永远不要站在用户的对立面,挑战大众的公知。
uni-app·app·apple
东坡肘子1 天前
完成 Liquid Glass 的适配了吗?| 肘子的 Swift 周报 #0102
swiftui·swift·apple
龙腾-虎跃2 天前
FreeSWITCH FunASR语音识别模块
人工智能·语音识别·xcode
2501_915106322 天前
Xcode 上传 ipa 全流程详解 App Store 上架流程、uni-app 生成 ipa 文件上传与审核指南
android·macos·ios·小程序·uni-app·iphone·xcode
kymjs张涛2 天前
零一开源|前沿技术周刊 #16
ios·apple·hacker news
zhanggui2 天前
iOS Debug Symbols
ios·xcode·debug symbox
大熊猫侯佩3 天前
iOS 26 仅需几行代码让 SwiftUI 7 液态玻璃界面焕发新春
前端·swiftui·apple
M-finder3 天前
Mac菜单栏综合工具FancyTool更新啦
mac·swift