摄影:产品经理烤秋刀鱼
新版本的 Homebrew,在你使用brew install xxx
或者brew upgrade xxx
的时候,会自动检查你是否有过期的程序,以及最近30天你是否执行过brew cleanup
。如果有过期的程序,那么它就会自动帮你升级。如果最近30天没有执行过brew cleanup
,那么它就会帮你自动执行这一行代码。
神经病,脑子被狗吃了才能想出这种馊主意。
就是这个智障提的建议:`brew cleanup` should be run automatically · Issue #4760 · Homebrew/brew · GitHub[1] 大家去喷他。
这个机制,破坏了我电脑上Python 所有的虚拟环境。
我电脑上的 Python 是使用 Homebrew 安装的。假设一开始我安装的版本是3.7。它会被Homebrew 安装到/usr/local/Cellar/python3/3.7.6_1
这种格式的路径下面。
然后我使用 Pipenv 基于这个 Python 创建了几十个虚拟环境。
由于Pipenv 是基于 Virtualenv 创建的虚拟环境,而 Virtualenv 在 macOS 和 Linux 下面,创建虚拟环境时,在虚拟环境里面用的是系统 Python 的软连接。而不是把系统 Python 的可执行文件复制到虚拟环境中。软连接相当于一个快捷方式,所以如果系统环境的 Python 没有了,虚拟环境下面的 Python 就无法使用,因为软连接连过去找不到目标。
当我在 Homebrew 中升级 Python 版本时,它会把新版本的 Python 下载下来,安装到另一个文件夹里面。然后修改/usr/local/bin/python
这个软连接,指向新的 Python 版本的可执行文件。但不改动老版本的 Python。这样一来,虚拟环境依然可以使用老版本的 Python,代码不受影响。
但是当执行brew cleanup
的时候,Homebrew 就会把这些老版本的程序删掉,从而导致虚拟环境损坏。
我原来一直是使用brew cleanup xxx
这样可以指定清除具体某些软件。如果不指定具体软件的名字,就会删除所有已经安装了新版本的过期的软件。Homebrew 这个30天自动清理,就会执行这个操作。这种默认自动清理的机制,剥夺了用户的知情权。
说回来,如何防止 Homebrew 自动升级与自动清理过期软件呢?
我们可以添加两个环境变量:
export HOMEBREW_NO_AUTO_UPDATE=1 export HOMEBREW_NO_INSTALL_CLEANUP=1
其中,第一个环境变量的作用是防止Homebrew 擅自升级所有软件。第二个环境变量是防止自动清理。
你可以在每次执行 Homebrew 相关命令时执行这两行。或者把他们添加到~/.zshrc
或者~/.bashrc
中永久生效。