npm ci แสดงข้อผิดพลาดกับ Angular 8 และโหนด 12 บน Windows: สร้างโหนด-gyp ใหม่


12

การตั้งค่าของฉัน:

  • Windows 10
  • NVM 1.1.7 สำหรับ Windows
  • โหนด 12.14.1 พร้อม npm 6.13.4
  • 8.2.14 เชิงมุมที่มี @ angular / cli 8.3.22

เพียงพยายามเรียกใช้เทมเพลตเชิงมุมเริ่มต้น:

> npm install -g @angular/cli # this installed the angular version mentioned above
> ng new test # Chose default options for the project
> cd test
> npm ci # lots of error messages

คำสั่งสุดท้ายส่งผลให้เกิดข้อผิดพลาดมากมายในผลลัพธ์ (แต่ไม่ล้มเหลวในคำสั่ง):

> fsevents@1.2.11 install C:\test\node_modules\@angular\compiler-cli\node_modules\fsevents
> node-gyp rebuild


C:\test\node_modules\@angular\compiler-cli\node_modules\fsevents>if not defined npm_config_node_gyp (node "C:\Users\foo\AppData\Roaming\nvm\v12.14.1\node_modules\npm\node_modules\npm-lifecycle\node-gyp-bin\\..\..\node_modules\node-gyp\bin\node-gyp.js" rebuild )  else (node "C:\Users\foo\AppData\Roaming\nvm\v12.14.1\node_modules\npm\node_modules\node-gyp\bin\node-gyp.js" rebuild )
gyp ERR! find Python
gyp ERR! find Python Python is not set from command line or npm configuration
gyp ERR! find Python Python is not set from environment variable PYTHON
gyp ERR! find Python checking if "python" can be used
gyp ERR! find Python - "python" is not in PATH or produced an error
gyp ERR! find Python checking if "python2" can be used
gyp ERR! find Python - "python2" is not in PATH or produced an error
gyp ERR! find Python checking if "python3" can be used
gyp ERR! find Python - "python3" is not in PATH or produced an error
gyp ERR! find Python checking if the py launcher can be used to find Python 2
gyp ERR! find Python - "py.exe" is not in PATH or produced an error
gyp ERR! find Python checking if Python is C:\Python27\python.exe
gyp ERR! find Python - "C:\Python27\python.exe" could not be run
gyp ERR! find Python checking if Python is C:\Python37\python.exe
gyp ERR! find Python - "C:\Python37\python.exe" could not be run
gyp ERR! find Python
gyp ERR! find Python **********************************************************
gyp ERR! find Python You need to install the latest version of Python.
gyp ERR! find Python Node-gyp should be able to find and use Python. If not,
gyp ERR! find Python you can try one of the following options:
gyp ERR! find Python - Use the switch --python="C:\Path\To\python.exe"
gyp ERR! find Python   (accepted by both node-gyp and npm)
gyp ERR! find Python - Set the environment variable PYTHON
gyp ERR! find Python - Set the npm configuration variable python:
gyp ERR! find Python   npm config set python "C:\Path\To\python.exe"
gyp ERR! find Python For more information consult the documentation at:
gyp ERR! find Python https://github.com/nodejs/node-gyp#installation
gyp ERR! find Python **********************************************************
gyp ERR! find Python
gyp ERR! configure error
gyp ERR! stack Error: Could not find any Python installation to use
gyp ERR! stack     at PythonFinder.fail (C:\Users\foo\AppData\Roaming\nvm\v12.14.1\node_modules\npm\node_modules\node-gyp\lib\find-python.js:307:47)
gyp ERR! stack     at PythonFinder.runChecks (C:\Users\foo\AppData\Roaming\nvm\v12.14.1\node_modules\npm\node_modules\node-gyp\lib\find-python.js:136:21)
gyp ERR! stack     at PythonFinder.<anonymous> (C:\Users\foo\AppData\Roaming\nvm\v12.14.1\node_modules\npm\node_modules\node-gyp\lib\find-python.js:225:16)
gyp ERR! stack     at PythonFinder.execFileCallback (C:\Users\foo\AppData\Roaming\nvm\v12.14.1\node_modules\npm\node_modules\node-gyp\lib\find-python.js:271:16)
gyp ERR! stack     at exithandler (child_process.js:302:5)
gyp ERR! stack     at ChildProcess.errorhandler (child_process.js:314:5)
gyp ERR! stack     at ChildProcess.emit (events.js:223:5)
gyp ERR! stack     at Process.ChildProcess._handle.onexit (internal/child_process.js:270:12)
gyp ERR! stack     at onErrorNT (internal/child_process.js:456:16)
gyp ERR! stack     at processTicksAndRejections (internal/process/task_queues.js:81:21)
gyp ERR! System Windows_NT 10.0.18362
gyp ERR! command "C:\\Program Files\\nodejs\\node.exe" "C:\\Users\\foo\\AppData\\Roaming\\nvm\\v12.14.1\\node_modules\\npm\\node_modules\\node-gyp\\bin\\node-gyp.js" "rebuild"
gyp ERR! cwd C:\Users\foo\repos\POC\angular\test1\node_modules\@angular\compiler-cli\node_modules\fsevents
gyp ERR! node -v v12.14.1
gyp ERR! node-gyp -v v5.0.5
gyp ERR!

ข้อผิดพลาดทั้งหมดที่เกี่ยวข้องกับfsevents, node-gypและงูหลามปฏิบัติการไม่ได้ถูกพบ ถูกต้องฉันไม่ได้ติดตั้งไพ ธ อน แต่มันไม่ได้เป็นข้อกำหนดเบื้องต้นสำหรับเชิงมุม

คำสั่งออกจริงด้วยรหัส 0 (แสดงถึงความสำเร็จ - นอกจากนี้ng build --prodทำงานหลังจากนั้น!) แต่ก็มีข้อผิดพลาดมากมายในผลลัพธ์

การลบnode_modulesโฟลเดอร์ด้วยตนเองและทำงานnpm installแทนการnpm ciสร้างผลลัพธ์ที่สั้นกว่ามากและไม่มีข้อผิดพลาดใด ๆ นอกจากนี้จะไม่แก้ไขpackage-lock.jsonไฟล์ซึ่งบ่งชี้ว่ามีการติดตั้งการพึ่งพาเวอร์ชันเดียวกัน

เกิดอะไรขึ้น? ทำไมข้อผิดพลาดมากมายเมื่อใช้npm ciแต่ไม่มีเมื่อใช้npm install?

คำตอบ:


23

ดูเหมือนว่าข้อผิดพลาดเกี่ยวข้องกับปัญหานี้และปัญหานี้

เชิงมุมขึ้นอยู่กับfsevents1.2.11 ซึ่งไม่ควรรวบรวมบน Windows (เป็นโมดูลที่เกี่ยวข้องกับดาร์วิน -OS) npm ciถูกบั๊กและละเว้นosฟิลด์ในโมดูลpackage.jsonดังนั้นจึงพยายามรวบรวมโมดูลอย่างไรก็ตามซึ่งล้มเหลวใน Windows

ข้อผิดพลาดไม่ได้เกิดขึ้นในเวอร์ชันเชิงมุมก่อนหน้านี้เพราะ fsevents 1.2.9 เป็นการดาวน์โหลดไบนารีโดยตรงจาก AWS แทนการรวบรวม แต่เนื่องจากขาดการเข้าถึงจาก devs ไปยังถัง AWS ซึ่งนำไปสู่ความเป็นไปไม่ได้ในการติดตั้งโมดูลบนโหนด 13 พวกเขาจึงปล่อยแพตช์ 1.2.11 เพื่อให้ผู้ใช้โหนด 13 สามารถติดตั้งแพ็กเกจได้

จนกว่าจะnpm ciได้รับการแก้ไขและ / หรือfseventsได้รับการปรับปรุงเป็น 2.x ในเชิงมุมการแก้ไขปัญหาบน Windows มีดังนี้:

  • เพียงแค่ละเว้นข้อผิดพลาด npm ciออกจากรหัสปัญญา 0 เนื่องจากการพึ่งพาเป็นทางเลือกดังนั้นจึงไม่ควรบล็อกสคริปต์การปรับใช้ของคุณ (เพียงแค่ทำให้มันช้าลงเล็กน้อยและทำให้ verbose มากขึ้น) ตัวเลือกที่แย่ที่สุดในความคิดของฉัน ...
  • ใช้npm installแทนnpm ciซึ่งจะประมวลผลosฟิลด์ของอย่างถูกต้องfseventsไฟล์อ้างอิง แต่สิ่งนี้อาจปรับปรุงการอ้างอิงของคุณดังนั้นจึงไม่เหมาะกับสคริปต์ CI เนื่องจากสามารถเปลี่ยนไฟล์ที่มีเวอร์ชันและไม่สร้างเอาต์พุตที่ทำซ้ำได้
  • ล็อคfseventsเวอร์ชันของโมดูลเป็น 1.2.9 แทนที่จะเป็น 1.2.11 ในไฟล์อ้างอิงของคุณเพื่อให้npm ciดาวน์โหลดไบนารีแทนการรวบรวม สิ่งนี้จะไม่ทำงานเมื่อใช้โหนด 13 เนื่องจากไม่มีไบนารีที่จะดาวน์โหลดสำหรับโหนดรุ่นนี้ นอกจากนี้ฉันไม่สามารถหาวิธีอัปเดตpackage.jsonไฟล์ให้ทำเช่นนั้นได้ ( สิ่งนี้ไม่ได้ผลสำหรับฉัน)
  • npm ci --no-optionalใช้ แต่น่าเสียดายที่นี้ไม่ได้ทำงานเพราะยังข้อผิดพลาดอีกnpm ciใน

2
งานนักสืบที่ยอดเยี่ยม; เจ็บปวดมากในช่วงหลายเดือนที่ผ่านมา
Maximilian Burszley

1
ขอบคุณสำหรับสิ่งนี้! ปัญหานี้ยังคงมีอยู่ในมุมที่ 9 หากมีใครสงสัย
ForestG

ย้อนกลับไปที่โหนด 10.x ทำงานให้ฉัน
ps2goat
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.