homebrew 安裝 formula 的不同歷史版本——以安裝 node 為例

来源:https://www.cnblogs.com/BlackStorm/archive/2018/10/28/homebrew-install-old-versions-take-node-for-example.html
-Advertisement-
Play Games

homebrew 安裝 formula 的不同歷史版本——以安裝 node 為例 系統環境 macOS Mojave 10.14 Homebrew 1.8.0 Homebrew/homebrew core (git revision 586b0f; last commit 2018 10 27) H ...


homebrew 安裝 formula 的不同歷史版本——以安裝 node 為例

系統環境

  • macOS Mojave 10.14
  • Homebrew 1.8.0
    Homebrew/homebrew-core (git revision 586b0f; last commit 2018-10-27)
    Homebrew/homebrew-cask (git revision 76ddc; last commit 2018-10-27)

背景

最近 nodejs 發佈了 11.0.0 版本,而我是用 brew 安裝了名為 node 的這個 formula ,現在 brew upgrade 會自動將 node 更新到最新版本,於是我遇到了一些問題:

  1. 一些需要編譯安裝的依賴包還不支持 node@11 ;
  2. 不知道如何自動切換兩個 formula ( node 和 node@10 )之間的可執行文件;
  3. 是否能夠設定某個 formula 不自動更新?

在經過一番折騰後,現在我刪掉了 node 和 node@10 兩個 formula ,包括之前安裝的歷史版本(所以算是多走了一點彎路),想要同時保留 10 和 11 兩個大版本,並可方便切換。

前置條件

若下列條件不滿足,可能導致需要額外的操作來解決環境問題,這些操作不在本文討論範圍內:

  1. 只通過 homebrew 來安裝 node ;
  2. 沒有使用如 n / nvm 等 node 版本管理工具;
  3. 某種意義下連接性良好的網路。

適用情況

本文覆蓋瞭如下四種情況:

  1. 某個 formula 跟隨著更新上來,沒有運行過 cleanup 或 force uninstall ,想切回舊版本的(見關鍵點三);
  2. 全新安裝且只想安裝某個 formula (如 node 而非 node@10 ),但又想先用著舊版本的(見解決方案一);
  3. 某個 formula 在用的是舊版本,但想切換編譯選項(如 [email protected] )重新安裝(同上);
  4. 在兩個 formula 之間切換,如一個是 LTS 版的,一個是不穩定版的(見解決方案二)。

關鍵點

如何在 brew install / upgrade 時禁止自動更新

這一步很關鍵,否則我們總是會安裝到最新版本。只要在運行命令前,設置環境變數 HOMEBREW_NO_AUTO_UPDATE 為 1 就可以了,比如:

$ HOMEBREW_NO_AUTO_UPDATE=1 brew install node

也可以直接寫進 shell 配置文件中(如 .bashrc / .zshrc 等):

export HOMEBREW_NO_AUTO_UPDATE=1

查看某個 formula 的本地已安裝版本

有兩種方式可查看,一是 brew list --versions ,輸出以空格分隔,簡潔明瞭,推薦使用:

$ brew list node --versions
node 11.0.0 10.12.0
$ brew list zsh --versions |tr ' ' '\n'
node
11.0.0
10.12.0

二是 brew info 在查看 formula 信息時也可看到本地已安裝的版本:

$ brew info node
$ brew info node |grep -i '\/cellar'
/usr/local/Cellar/node/10.12.0 (3,668 files, 41.7MB)
/usr/local/Cellar/node/11.0.0 (3,665 files, 42MB) *

後面帶有的星號 * 表示當前激活的版本。

切換某個 formula 的版本

自有的 brew switch 命令即可,之前感覺 brew 較易上手,安裝後沒看文檔直接用到現在,所以不知道這個命令。命令的說明也很直觀:

brew switch formula version:
    Symlink all of the specific version of formula's install to Homebrew prefix.

直接鍵盤一頓敲就行了,如 brew switch node 10.12.0

解決方案

安裝某個 formula 的歷史版本

  1. 切換到 brew 的倉庫目錄下

    $ cd "$(brew --repo homebrew/core)"
  2. 查看某個 formula 的 git 歷史記錄

    $ git log master -- Formula/node.rb

    在裡面找到想要的歷史版本,比如這個就挺像我所需要的:

    commit b801cc6b71e7c09448b4f823e493710665de68eb
    Author: BrewTestBot <[email protected]>
    Date:   Thu Oct 11 00:12:43 2018 +0000
    
        node: update 10.12.0 bottle.
  3. 檢出 git 歷史提交

    $ git checkout b801cc6b71e7c09448b4f823e493710665de68eb
  4. 在禁止自動更新的前提下安裝這個 formula

    $ HOMEBREW_NO_AUTO_UPDATE=1 brew install node [email protected]
  5. 由於剛纔第 3 步後處於分離頭指針狀態下,記得要切回來

    $ git checkout master
  6. 升級這個 formula 試試

    $ brew upgrade node
  7. 檢查當前版本,應該是最新的,現在再把它切回來

    $ node -v
    v11.0.0
    $ brew switch node 10.12.0
    Cleaning /usr/local/Cellar/node/10.12.0
    Cleaning /usr/local/Cellar/node/11.0.0
    7 links created for /usr/local/Cellar/node/10.12.0
    $ node -v
    v10.12.0

在兩個 formula 之間切換

我們也可以在 node 和 node@10 兩個 formula 之間切換文件鏈接。但是註意,這種方法可能會在運行 brew doctor 時產生警告,因為可能會有一個不是 keg-only 的包沒有被鏈接到 Cellar 中(如為了使用 node@10 而解除了 node 的鏈接),這個警告可以不去理會,但必須記住我們做過這樣的操作。

  1. 假定已經安裝了 node ,現在安裝 node@10 ,鍵盤一頓亂敲

    $ brew install node@10

    通常像這樣名字後面帶有版本號的 formula 都是 keg-only 的,簡單來說就是 brew 不會自動幫我們鏈接文件

  2. 先解除 node 的文件鏈接
    shell $ brew unlink node

  3. 鏈接 node@10 的文件

    $ brew link node@10

    這時會提示這個包是 keg-only 的,需要加上 --force 選項。如果第 2 步沒有進行,還會提示你需要先解除 node 的鏈接,或者直接用 --overwrite 選項覆蓋原有的鏈接。由於 npm 目錄一定需要覆蓋,所以我們總是可以打開 --overwrite 選項:

    $ brew link node@10 --force --overwrite
  4. 檢查當前版本,在解決方案一中提到過了,方法也有很多種,此處略過。

後續問題

  1. 全局安裝的包支持的 node 版本可能不同
    是的,這個問題一定會存在,建議通過切換 npm prefix 路徑解決,把不同版本 node 下安裝的全局包隔離開來。當然 nvm 等方案也可以解決問題,但本文是不一樣的煙火。

    $ mkdir -p ~/.npm-node10/npm-global
    $ npm config set prefix ~/.npm-node10/npm-global
    $ export PATH="$HOME/.npm-node10/npm-global/bin:$PATH"

    手動切換確實比較繁瑣,可以寫個 shell 腳本把切換 formula 和切換 npm prefix 結合起來。

  2. 如何固定某個 formula 的版本?
    雖然說不運行 brew upgrade 就一直是固定的版本,但如果想只固定某個 formula 的版本而允許其他可以升級,也是極好的。自帶的 pin 、 unpin 命令就是用來解決這一問題,如: brew pin node

  3. 如何刪除某個 formula 的舊版本?
    儘管 brew cleanup 可以刪除一個 formula 的所有舊版本,但通常我們可能只想刪除某幾個太舊且多餘的版本而不是全部。 brew 沒有提供這樣的命令,我們可以直接從 Cellar 裡面刪除:

    $ brew info node |grep -i '\/cellar'
    /usr/local/Cellar/node/10.12.0 (3,668 files, 41.7MB)
    /usr/local/Cellar/node/11.0.0 (3,665 files, 42MB) *
    $ rm -rf /usr/local/Cellar/node/10.12.0

    初步測試未發現有副作用,歡迎討論和建議。

  4. 如何在升級時自動刪除舊版本?
    根據 brew upgrade 命令的說明,設置一個 HOMEBREW_UPGRADE_CLEANUP 環境變數就好了,比較簡單。

參考資料

  1. Tips and Tricks - Homebrew Documentation
  2. Homebrew terminology - Homebrew Documentation
  3. FAQ - Homebrew Documentation
  4. homebrew - how to install older versions - Stack Overflow
  5. Homebrew install specific version of formula? - Stack Overflow
  6. Using Homebrew how do I remove some specific versions but not all old versions - Stack Overflow



本文基於 知識共用許可協議知識共用署名-非商業性使用-相同方式共用 4.0 國際許可協議 發佈,歡迎引用、轉載或演繹,但是必須保留本文的署名 BlackStorm 以及本文鏈接 http://www.cnblogs.com/BlackStorm/p/homebrew-install-old-versions-take-node-for-example.html ,且未經許可不能用於商業目的。如有疑問或授權協商請與我聯繫


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、asp 的上傳 有兩個突出問題:1. 文件上傳框風格和整個頁面風格不搭配。 2. 上傳時是整個頁面回發,和FineUI預設的AJAX風格也不搭。 2、fineui 的上傳 下麵來看看FileUpload的屬性: 1. ButtonText:按鈕文本。 1. ButtonOnly:是否只顯示按鈕, ...
  • vs 打開項目報錯; 解決方法:刪除我的文檔下IISEXpress文件夾,然後重啟電腦。 ...
  • 按f1 搜索 Configore Display Language 設置 zh-cn 關閉軟體重啟。 如果重啟菜單等還是英文的,在商店查看已安裝的插件,把中文插件重新安裝一遍,然後重啟軟體。 ...
  • mknod 創建塊設備或者字元設備文件。此命令的適用範圍:RedHat、RHEL、Ubuntu、CentOS、SUSE、openSUSE、Fedora。 1、語法 mknod [選項] 設備名 設備類型 主設備號 次設備號 2、選項參數列表 選項 說明 --version 顯示命令版本信息 --he ...
  • 一、概述 記憶體管理涵蓋領域: 記憶體中的物理記憶體頁管理; 分配大塊記憶體的伙伴系統; 分配較小塊記憶體的slab、slub和slob分配器; 分配連續記憶體塊的vmalloc機制; 進程的地址空間。 Linux內核一般將處理器的虛擬地址分為兩個部分,以IA-32為例,地址空間在用戶進程和內核之間的劃分比例為 ...
  • 我們前面提到linux有兩種方法激活調度器:核心調度器和 周期調度器 一種是直接的, 比如進程打算睡眠或出於其他原因放棄CPU 另一種是通過周期性的機制, 以固定的頻率運行, 不時的檢測是否有必要 因而內核提供了兩個調度器 主調度器 , 周期性調度器 ,分別實現如上工作, 兩者合在一起就組成了 核心 ...
  • 在os層numa關閉時,打開bios層的numa會影響性能,QPS會下降15-30%; 在bios層面numa關閉時,無論os層面的numa是否打開,都不會影響性能。 安裝numactl: #yum install numactl -y #numastat 等同於 cat /sys/devices/ ...
  • Tmux是一個優秀的終端復用軟體,類似GNU Screen,但來自於OpenBSD,採用BSD授權。使用它最直觀的好處就是,通過一個終端登錄遠程主機並運行tmux後,在其中可以開啟多個控制台而無需再“浪費”多餘的終端來連接這台遠程主機。是BSD實現的Screen替代品,相對於Screen,它更加先進 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...