首頁 > web前端 > js教程 > npm i 與 npm ci

npm i 與 npm ci

Patricia Arquette
發布: 2024-11-28 16:02:11
原創
201 人瀏覽過

npm i vs npm ci

我們都知道 npm install,但有些人可能不知道 npm ci(全新安裝)。這個指令在 CI 環境中非常有用。使用 npm ci 可以使您的建造管道更快、更穩定。學習這些命令可以幫助您更了解 npm install 以及為什麼 package-lock.json 和 package.json 如此重要。了解這些基礎知識可以讓您更加清晰。

什麼是 npm ci(全新安裝)?

npm ci 是一個用於在專案中安裝依賴項的命令,注重速度和一致性。它對於持續整合 (CI) 設定特別有用。

它與 npm install 有什麼不同?

  • 更快的安裝

    npm ci 會跳過更新 package-lock.json。它嚴格遵循鎖定檔案的依賴關係,使流程更快且可預測。

  • 嚴格鎖定檔案:

    它使用 package-lock.json 中的確切依賴項版本。如果 package.json 和 package-lock.json 之間有任何不匹配,則會拋出錯誤。這可確保所有環境(本地、CI、生產)使用相同的依賴項。

  • 乾淨的石板

    在安裝之前,npm ci 會刪除node_modules 資料夾以重新開始。

何時使用?

  • CI/CD 管道:非常適合需要快速、一致安裝而無需更新的自動化建置系統。
  • 受信任的鎖定檔案:當您希望依賴項與 package-lock.json 中定義的內容完全匹配時使用。

這是一個快速參考表,透過了解 npm install 和 npm ci 之間的主要區別,為您打開許多隱藏區域:

步驟 npm install npm ci
1。依賴解析 根據 package.json 解決依賴關係並更新 package-lock.json 以反映任何變更。 跳過解析,使用 package-lock.json 中的確切版本,而不參考 package.json 的版本範圍。
2。版本相容性檢查 確保相依性符合 package.json 中指定的範圍,如果需要更新 package-lock.json。 要求 package-lock.json 中的版本與 package.json 完全匹配;如果不同步就會失敗。
3。 node_modules 清理 僅安裝遺失或更新的軟體包,而不刪除node_modules,保持現有的依賴項不變。 在重新安裝所有新內容之前完全刪除node_modules。
4。鎖定檔案產生 如果不存在則產生一個新的package-lock.json;根據 package.json 的變更進行更新。 需要現有的 package-lock.json,如果遺失或與 package.json 不同步,則會失敗。
5。與 package.json 同步 更新 package-lock.json 以與 package.json 中任何新的、修改的或刪除的依賴項保持一致。 要求 package-lock.json 與 package.json 完全匹配;如果不是,則失敗,確保嚴格的版本一致性。
6。安裝依賴項 根據 package.json 將依賴項安裝到 node_modules 中,並使用任何已解析的版本更新 package-lock.json。 完全按照 package-lock.json 中指定的方式安裝依賴項,確保可重複性並忽略 package.json 中的版本範圍。
7。鎖定檔案修改 修改 package-lock.json 以自動符合 package.json 變更。 無論package.json如何變化,都不會修改package-lock.json,保持一致性。
8。網路請求 取得在node_modules中未找到的任何新依賴項或更新。 僅取得 package-lock.json 中列出的依賴項,跳過額外檢查。
9。速度 由於依賴項解析、潛在的鎖定檔案更新和增量安裝而較慢。 更快,僅使用 package-lock.json 進行精確安裝,最大限度地減少處理。
10。文件優先權 package.json 優先:根據它解析依賴項,並更新 package-lock.json 以反映任何變更。 package-lock.json 優先:安裝時使用準確的版本,忽略 package.json,除非檢查同步錯誤(如果不符合則失敗)。
11。理想用例 最適合修改或新增相依性時的本機開發。 最適合 CI/CD 環境、生產或任何時間一致性、速度和可重複性至關重要。

以上是npm i 與 npm ci的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:dev.to
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板