我們都知道 npm install,但有些人可能不知道 npm ci(全新安裝)。這個指令在 CI 環境中非常有用。使用 npm ci 可以使您的建造管道更快、更穩定。學習這些命令可以幫助您更了解 npm install 以及為什麼 package-lock.json 和 package.json 如此重要。了解這些基礎知識可以讓您更加清晰。
npm ci 是一個用於在專案中安裝依賴項的命令,注重速度和一致性。它對於持續整合 (CI) 設定特別有用。
更快的安裝:
npm ci 會跳過更新 package-lock.json。它嚴格遵循鎖定檔案的依賴關係,使流程更快且可預測。
嚴格鎖定檔案:
它使用 package-lock.json 中的確切依賴項版本。如果 package.json 和 package-lock.json 之間有任何不匹配,則會拋出錯誤。這可確保所有環境(本地、CI、生產)使用相同的依賴項。
乾淨的石板:
在安裝之前,npm ci 會刪除node_modules 資料夾以重新開始。
這是一個快速參考表,透過了解 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中文網其他相關文章!