npm ci विंडोज पर कोणीय 8 और नोड 12 के साथ त्रुटियों को उत्पन्न करता है: नोड-जिप पुनर्निर्माण


12

मेरा सेटअप:

  • विंडोज 10
  • विंडोज के लिए एनवीएम 1.1.7
  • एनपीएम 6.13.4 के साथ नोड 12.14.1
  • कोणीय 8.2.14 @ कोणीय / 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 पर निर्भर करता है , जिसे विंडोज पर संकलित नहीं किया जाना चाहिए (यह एक डार्विन-ओएस संबंधित मॉड्यूल है)। npm ciको खराब कर दिया जाता है और osमॉड्यूल में फ़ील्ड को अनदेखा कर देता है package.json, इसलिए यह वैसे भी मॉड्यूल को संकलित करने की कोशिश करता है, जो विंडोज पर विफल रहता है।

यह त्रुटि पिछले कोणीय संस्करणों में नहीं हुई थी क्योंकि fsevents1.2.9 सीधे उन्हें संकलित करने के बजाय AWS से बायनेरी डाउनलोड कर रहा था। लेकिन देवताओं से एडब्ल्यूएस बाल्टी तक पहुंच के नुकसान के कारण, नोड 13 पर मॉड्यूल को स्थापित करने की असंभवता के कारण, उन्होंने पैकेज को स्थापित करने के लिए नोड 13 उपयोगकर्ताओं को अनुमति देने के लिए 1.2.11 पैच जारी किया।

जब तक npm ciफिक्स्ड और / या fseventsकोणीय में 2.x तक अपडेट नहीं किया जाता है, तब तक विंडोज पर वर्कअराउंड या तो हैं:

  • बस त्रुटि को नजरअंदाज करें। npm ciबुद्धि कोड 0 से बाहर निकलता है क्योंकि निर्भरता वैकल्पिक है, इसलिए इसे आपकी परिनियोजन स्क्रिप्ट को ब्लॉक नहीं करना चाहिए (बस इसे थोड़ा धीमा करें और इसे और अधिक क्रिया करें)। मेरी राय में सबसे कम बुरा विकल्प ...
  • npm installइसके बजाय का उपयोग करें npm ci, जो निर्भरता फ़ाइल के osक्षेत्र को सही ढंग से संसाधित करेगा fsevents। लेकिन यह संभावित रूप से आपकी निर्भरता को अपडेट करेगा, इसलिए यह वास्तव में CI स्क्रिप्ट के लिए उपयुक्त नहीं है, क्योंकि यह संस्करणित फ़ाइलों को बदल सकता है, और एक दोहराने योग्य उत्पादन नहीं करता है।
  • fseventsमॉड्यूल संस्करण को अपनी निर्भरता फ़ाइल में 1.2.11 के बजाय 1.2.9 पर लॉक करें , ताकि npm ciउन्हें संकलित करने के बजाय बायनेरिज़ डाउनलोड करें। नोड 13 का उपयोग करते समय यह काम नहीं करेगा, क्योंकि नोड के इस संस्करण को डाउनलोड करने के लिए कोई बायनेरिज़ नहीं हैं। इसके अलावा, मुझे यह नहीं पता चला कि किसी को package.jsonफ़ाइल को अपडेट करने के लिए कैसे करना चाहिए ( यह मेरे लिए काम नहीं करता है)।
  • का उपयोग करें npm ci --no-optional। दुर्भाग्य से यह काम नहीं करता है, क्योंकि अभी तक एक और बग में npm ci

2
शानदार जासूसी का काम; पिछले कई महीनों से बहुत दर्दनाक है।
मैक्सिमिलियन बर्स्ज़ले

1
इसके लिए शुक्रिया! यह समस्या अभी भी कोणीय 9 के साथ मौजूद है, अगर कोई भी सोच रहा है।
फॉरेस्ट

Node 10.x पर वापस आना मेरे लिए काम कर रहा है
ps2goat
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.