Jenkins 構建 Node 項目報錯解析與解決——pnpm lockfile 問題實戰

在使用 Jenkins 自動化構建 Node.js 項目時,經常會遇到類似報錯:

ERR_PNPM_OUTDATED_LOCKFILE? Cannot install with "frozen-lockfile" because pnpm-lock.yaml is not up to date with package.json
Error: Cannot find module 'node_modules/vite/bin/vite.js'

對于初學者來說,這種報錯可能很迷惑。本文帶你從原理到實操,徹底搞懂問題原因和解決方案。


一、問題現象

在 Jenkins CI 上執行構建任務時,可能出現以下情況:

  1. pnpm install 失敗,報錯:
ERR_PNPM_OUTDATED_LOCKFILE? Cannot install with "frozen-lockfile" because pnpm-lock.yaml is not up to date with package.json
  1. 構建命令報錯:
Error: Cannot find module 'node_modules/vite/bin/vite.js'
  1. 打包步驟失敗:
zip warning: name not matched: dist
zip error: Nothing to do!

二、問題根源分析

1. pnpm lockfile 不一致

  • pnpm 使用 pnpm-lock.yaml 來鎖定依賴版本,保證不同環境安裝依賴一致。

  • CI 環境(如 Jenkins)默認啟用 frozen-lockfile 模式,即:

    • 不會自動修改 lockfile
    • 如果 package.json 中新增或修改了依賴,而 lockfile 未更新,就會報錯。

典型場景

  • 本地新增依賴:
pnpm add @zxing/browser jsqr qrcode-decoder quagga
  • package.json 改了,但 pnpm-lock.yaml 沒更新或沒提交到 Git。
  • Jenkins 在 CI 環境拉取代碼后,執行 pnpm install 時就報錯了。

2. node_modules 缺失

由于 pnpm install 失敗:

  • node_modules 沒生成完整依賴
  • 構建工具(如 Vite)找不到模塊:
Cannot find module 'node_modules/vite/bin/vite.js'
  • 構建中斷 → 打包 dist 文件失敗

三、解決方案

1. 本地更新 lockfile 并提交(推薦)

  1. 在本地項目根目錄執行:
pnpm install
  • 會根據 package.json 更新 pnpm-lock.yaml
  • 注意不要使用 --frozen-lockfile,否則不會更新。
  1. 提交更新:
git add package.json pnpm-lock.yaml
git commit -m "chore: update lockfile after adding new dependencies"
git push
  1. Jenkins 再次構建:
  • CI 拉取最新代碼
  • pnpm install 會順利安裝依賴
  • 構建正常 → 打包成功

2. CI 臨時解決方案(不推薦)

如果只是測試或臨時構建,可以在 Jenkins 構建腳本里加:

pnpm install --no-frozen-lockfile
  • 會忽略 lockfile 和 package.json 的不一致
  • 強制安裝依賴
  • ?? 風險:可能導致不同環境依賴版本不一致,不適合長期使用

3. 確保構建路徑正確

在 Jenkins 中,確保工作目錄存在:

cd /var/jenkins_home/workspace/jxc-web
pnpm install
  • 如果 workspace 被清理或不存在,會報:
Error: ENOENT: no such file or directory, uv_cwd
  • Jenkins job 配置中可以取消“構建前刪除工作區”,或者在構建腳本里自動創建目錄:
mkdir -p /var/jenkins_home/workspace/jxc-web

4. 檢查 Node.js 和 pnpm 版本

確保 Jenkins 使用的 Node.js 與本地一致:

node -v
pnpm -v

不同版本可能導致依賴安裝或 vite 構建失敗。


四、Jenkins 構建推薦流程

一個推薦的 Jenkins 構建腳本:

#!/bin/bash
set -e# 確保工作區存在
mkdir -p /var/jenkins_home/workspace/jxc-web
cd /var/jenkins_home/workspace/jxc-web# 拉取最新代碼
git reset --hard
git clean -fd
git pull origin main# 安裝依賴
pnpm install --frozen-lockfile# 構建項目
pnpm run build:dev# 打包 dist
zip -r dist.zip dist

? 關鍵點:

  • --frozen-lockfile 保證 CI 與 lockfile 一致
  • 如果 lockfile 有變動 → 在本地更新并提交
  • 確保 workspace 路徑存在,避免 uv_cwd 錯誤
  • Node.js、pnpm 版本與本地一致

五、總結

  • Jenkins 不會自動更新 pnpm lockfile → 鎖文件必須與 package.json 保持一致

  • 構建失敗 的根本原因是依賴沒裝完整

  • 最佳實踐

    1. 本地修改依賴后同步更新 lockfile
    2. 提交到 Git
    3. CI 使用 --frozen-lockfile 保證環境一致

這樣就可以避免:

  • ERR_PNPM_OUTDATED_LOCKFILE
  • Cannot find module 'vite'
  • 打包 dist 失敗

小白提示:

每次新增依賴后記得跑 pnpm install 并提交 pnpm-lock.yaml,CI 構建才不會報錯!


本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/96157.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/96157.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/96157.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Kafka在多環境中安全管理敏感

1. 配置提供者是什么? 配置提供者(ConfigProvider)是一類按需“拉取配置”的組件:應用讀取配置時,按約定的占位符語法去外部來源(目錄、環境變量、單一 properties 文件、你自定義的來源……)取…

編程工具的演進邏輯:從Python IDLE到Arduino IDE的深度剖析

引言:工具進化的本質 在編程學習與開發的道路上,我們總會與各種各樣的工具相遇。一個有趣的現象是,無論是初學者的第一款工具Python IDLE,還是硬件愛好者常用的Thonny和Arduino IDE,它們都自稱“集成開發環境”(IDE)。這背后隱藏著怎樣的邏輯? 本文將帶你深入分析這三…

p10k configure執行報錯: ~/powerlevel10k/config/p10k-lean.zsh is not readable

[ERROR] p10k configure: ~/powerlevel10k/config/p10k-lean.zsh is not readable 背景 我移動了Powerlevel10k文件夾的位置,導致p10k configure命令找不到powerlevel10k文件夾的位置。 原來Powerlevel10k的位置:~/powerlevel10k 移動后Powerlevel10k的位…

Java 學習筆記(進階篇3)

1. 美化界面關鍵邏輯 1:// 相對路徑:直接從項目的 src 目錄開始寫,不包含 D:\ 和個人名字 ImageIcon bg new ImageIcon("src/image/background.png"); JLabel background new JLabel(bg);這兩行代碼是 Swing 中加載并顯示圖片的經…

BFD 概述

BFD簡介1.BFD:Bidirectional Forwarding Detection,雙向轉發檢查概述:毫秒級鏈路故障檢查,通常結合三層協議(如靜態路由、vrrp、 ospf、 BGP等)實現鏈路故障快速切換。作用:① 檢測二層非直連故障② 加快三層協議收斂底…

【嵌入式DIY實例-ESP32篇】-Flappy Bird游戲

Flappy Bird游戲 文章目錄 Flappy Bird游戲 1、游戲介紹 2、硬件準備與接線 3、代碼實現 《Flappy Bird》游戲以其引人入勝的玩法和簡約的設計風靡全球。本文將探討如何使用 OLED SSD1306 顯示屏和 ESP32 微控制器重現這款經典游戲。這個 DIY 項目不僅充滿樂趣,也是學習編程和…

[數據結構——lesson2.順序表]

目錄 學習目標 引言 1.什么是線性表? 2.什么是順序表? 2.1概念及結構 2.2 接口實現 2.2.1順序表的功能 1.順序表的初始化 2.打印數據 3.尾插數據 (1)檢查空間 (2)插入數據 4.尾刪數據 5.頭插數據 6.頭刪數據 7.數據查找 8.指定位置數據…

ChatGPT大模型訓練指南:如何借助動態代理IP提高訓練效率

隨著人工智能技術的飛速發展,ChatGPT等大型語言模型(LLM)已成為科技界和產業界關注的焦點。模型的訓練過程耗時、耗資源且對網絡環境要求極高。尤其是在需要模擬真實用戶行為、進行大規模數據爬取或分布式訓練的場景下,單一IP地址…

Docker 學習筆記(六):多容器管理與集群部署實踐

Docker Docker-compose 單個 Dockerfile 可定義單容器應用,但日常工作中,Web 項目等常需 Web 服務、數據庫、負載均衡等多容器配合,手動按序啟停容器會導致維護量大、效率低。 Docker Compose 是高效的多容器管理工具,通過單個 do…

C++類和對象初識

面向過程 1.1 面向過程特點 1.2 通俗解釋:煮方便面 1.3 面向過程實現代碼 1.4 特點總結面向對象 2.1 面向對象特點 2.2 通俗解釋:對象協作思維 2.3 面向對象實現代碼 2.4 特點總結面向對象和面向過程總結C 面向對象介紹 4.1 面向對象三大基本特征封裝&am…

C++ Int128 —— 128位有符號整數類實現剖析

🧠 C Int128 —— 128位有符號整數類實現剖析 引用:openppp2/ppp/Int128.h 🏗? 1. 存儲結構設計 #mermaid-svg-2JDFsdz6MTbX253D {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-sv…

【C 語言生成指定范圍隨機數(整數 + 小數):原理、實現與避坑指南】

概述 在 C 語言開發中,生成指定范圍的隨機數是高頻需求(如游戲隨機道具、數據模擬、測試用例生成等)。但很多新手會卡在 “范圍控制”“隨機數重復”“小數生成” 等問題上。本文結合實戰場景,從原理到代碼詳細講解如何生成 1100、…

一個簡單的langgraph agent系統

本文基于langgraph的預制件 Agent Chat UI和《搭建一個本地langgraph服務》中的本地服務構建一個簡單的agent系統。 說明:Agent Chat UI需要nodejs版本18及以上,而nodejs18需要的glibc版本為2.28,本人使用操作系統為ubuntu18.04,g…

通過SSH來推送本地文件夾到Github

配置SSH git使用SSH配置, 初始需要以下三個步驟 使用秘鑰生成工具生成rsa秘鑰和公鑰 將rsa公鑰添加到代碼托管平臺 將rsa秘鑰添加到ssh-agent中,為ssh client指定使用的秘鑰文件 具體操作如下: 第一步:檢查本地主機是否已經存在…

視頻轉webp批量處理工具哪個好?這里有答案

你是不是也遇到過這樣的困擾:手機里存滿了精彩的短視頻,想做成動圖分享到社交媒體,卻發現轉換后的GIF文件巨大無比,畫質還慘不忍睹?要怎么把手機視頻轉webp,才能既保持高清畫質,又能大幅減小文件…

【Fastjson】Fastjson2 在不同 Modules 模塊包下,@JSONField name映射無法反序列化的 BUG 及解決

問題:在使用 alibaba fastjson2 做 JSONField 字段名映射時,在同模塊包下 Flink Jar 任務正常映射,本地測試正常映射,但是將兩個模塊包上傳至 Flink Cluster 之后,出現反序列化異常,子模塊無法反序列化父模…

Go語言基礎---數據類型間的故事

Go語言基礎—數據類型間的故事 目錄 前言基本數據類型 整形字節特殊整形unsafe.Sizeof數字字面量語法浮點型布爾值字符串byte和rune類型 運算符 算術運算符關系運算符邏輯運算符位運算符賦值運算符 前言 Go語言是Google開發的一種靜態強類型、編譯型語言。Go語言語法與C相近…

dedecms軟件等級★號改成圖片圖標顯示的辦法

我們在用到dedecms織夢的軟件模型&#xff0c;在調用軟件星級的時候&#xff0c;要把默認的星號改為圖片&#xff0c;這個要怎么操作呢&#xff1f;1、軟件模型管理里面-字段管理-字段配置softrankislink一行改為&#xff1a;<field:softrank itemname軟件等級 typeint isnu…

windows下安裝claude code+國產大模型glm4.5接入(無需科學上網)

下載安裝node.js https://nodejs.org/en/download 安裝版.msi 直接下載安裝即可 免安裝版.zip 1.解壓下載的壓縮包 2.創建數據緩存存儲目錄cache和全局安裝工具目錄global 3.配置環境變量 【我的電腦】右鍵選中【屬性】-> 找到【高級系統設置】-> 右下角【環境變量…

嵌入式 - ARM4

裸機實現LED閃爍一、啟動代碼1. 異常向量表配置1. .global匯編器指令&#xff0c;全局定義標簽_start&#xff0c;作為匯編程序的默認起點2. 配置標簽配置標簽時可以前置加_ &#xff0c;以便和普通標簽或系統標簽做區分3. 異常向量表ARM架構規定異常向量表位置固定&#xff0c…