नोड.जेएस - स्केलिंग एप्लीकेशन

Node.js एक एकल-थ्रेड मोड में चलता है, लेकिन यह समसामयिकता को संभालने के लिए एक इवेंट-संचालित प्रतिमान का उपयोग करता है। यह मल्टी-कोर सीपीयू आधारित प्रणालियों पर समानांतर प्रसंस्करण का लाभ उठाने के लिए बाल प्रक्रियाओं के निर्माण की सुविधा भी देता है।

बाल प्रक्रियाओं में हमेशा तीन धाराएँ होती हैं child.stdin, child.stdout, तथा child.stderr जिसे मूल प्रक्रिया की stdio धाराओं के साथ साझा किया जा सकता है।

नोड प्रदान करता है child_process मॉड्यूल जिसमें बच्चे की प्रक्रिया बनाने के लिए निम्नलिखित तीन प्रमुख तरीके हैं।

  • exec - child_process.exec विधि शेल / कंसोल में एक कमांड चलाता है और आउटपुट को बफ़र करता है।

  • spawn - child_process.spawn किसी दिए गए कमांड के साथ एक नई प्रक्रिया शुरू करता है।

  • fork - चाइल्ड_प्रोसेस.फॉर्क विधि बच्चे की प्रक्रिया बनाने के लिए स्पॉन () का एक विशेष मामला है।

निष्पादन () विधि

child_process.exec विधि एक शेल में कमांड चलाता है और आउटपुट को बफ़र करता है। इसके निम्नलिखित हस्ताक्षर हैं -

child_process.exec(command[, options], callback)

मापदंडों

यहाँ प्रयुक्त मापदंडों का वर्णन है -

  • command (स्ट्रिंग) अंतरिक्ष-अलग-अलग तर्कों के साथ चलने की आज्ञा

  • options (ऑब्जेक्ट) में निम्नलिखित विकल्पों में से एक या अधिक शामिल हो सकते हैं -

    • cwd (स्ट्रिंग) बच्चे की प्रक्रिया की वर्तमान कार्यशील निर्देशिका

    • env (ऑब्जेक्ट) पर्यावरण कुंजी-मूल्य जोड़े

    • encoding (स्ट्रिंग) (डिफ़ॉल्ट: 'utf8')

    • shell (स्ट्रिंग) शेल को UNIX पर (डिफ़ॉल्ट: '/ बिन / श'), विंडोज पर 'cmd.exe' के साथ कमांड निष्पादित करने के लिए, शेल को Windows पर UNIX या / s / c पर -c स्विच को समझना चाहिए। कमांड लाइन पार्सिंग cmd.exe के साथ संगत होनी चाहिए।)

    • timeout (संख्या) (डिफ़ॉल्ट: 0)

    • maxBuffer (संख्या) (डिफ़ॉल्ट: 200 * 1024)

    • killSignal (स्ट्रिंग) (डिफ़ॉल्ट: 'SIGTERM')

    • uid (संख्या) प्रक्रिया की उपयोगकर्ता पहचान सेट करता है।

    • gid (संख्या) प्रक्रिया की समूह पहचान सेट करता है।

  • callback फ़ंक्शन को तीन तर्क मिलते हैं error, stdout, तथा stderr जब प्रक्रिया समाप्त हो जाती है तो आउटपुट के साथ बुलाया जाता है।

निष्पादन () विधि अधिकतम आकार के साथ एक बफर लौटाती है और प्रक्रिया समाप्त होने का इंतजार करती है और एक ही बार में सभी बफ़र किए गए डेटा को वापस करने की कोशिश करती है।

उदाहरण

चलिए दो js फाइल बनाते हैं जिनका नाम support.js और master.js है -

File: support.js

console.log("Child Process " + process.argv[2] + " executed." );

File: master.js

const fs = require('fs');
const child_process = require('child_process');

for(var i=0; i<3; i++) {
   var workerProcess = child_process.exec('node support.js '+i,function 
      (error, stdout, stderr) {
      
      if (error) {
         console.log(error.stack);
         console.log('Error code: '+error.code);
         console.log('Signal received: '+error.signal);
      }
      console.log('stdout: ' + stdout);
      console.log('stderr: ' + stderr);
   });

   workerProcess.on('exit', function (code) {
      console.log('Child process exited with exit code '+code);
   });
}

अब परिणाम देखने के लिए मास्टर दौड़ें-

$ node master.js

आउटपुट सत्यापित करें। सर्वर शुरू हो गया है।

Child process exited with exit code 0
stdout: Child Process 1 executed.

stderr:
Child process exited with exit code 0
stdout: Child Process 0 executed.

stderr:
Child process exited with exit code 0
stdout: Child Process 2 executed.

स्पॉन () विधि

child_process.spawn विधि किसी दिए गए कमांड के साथ एक नई प्रक्रिया शुरू करती है। इसके निम्नलिखित हस्ताक्षर हैं -

child_process.spawn(command[, args][, options])

मापदंडों

यहाँ प्रयुक्त मापदंडों का वर्णन है -

  • command (स्ट्रिंग) चलाने की आज्ञा

  • args (ऐरे) स्ट्रिंग तर्कों की सूची

  • options (ऑब्जेक्ट) में निम्नलिखित विकल्पों में से एक या अधिक शामिल हो सकते हैं -

    • cwd (स्ट्रिंग) बच्चे की प्रक्रिया की वर्तमान कार्यशील निर्देशिका।

    • env (ऑब्जेक्ट) पर्यावरण कुंजी-मूल्य जोड़े।

    • stdio (एरियर) स्ट्रिंग चाइल्ड के स्टीडियो कॉन्फ़िगरेशन।

    • customFds (एरियर) बच्चे को स्टैडियो के लिए उपयोग करने के लिए डिप्रेस्ड फाइल डिस्क्रिप्टर।

    • detached (बूलियन) बच्चा एक प्रक्रिया समूह का नेता होगा।

    • uid (संख्या) प्रक्रिया की उपयोगकर्ता पहचान सेट करता है।

    • gid (संख्या) प्रक्रिया की समूह पहचान सेट करता है।

स्पॉन () विधि रिटर्न स्ट्रीम (stdout और stderr) है और इसका उपयोग तब किया जाना चाहिए जब प्रक्रिया डेटा की मात्रा वापस कर देती है। जैसे ही प्रक्रिया निष्पादित होने लगती है स्पॉन () प्रतिक्रिया प्राप्त करना शुरू कर देता है।

उदाहरण

Support.js और master.js नाम की दो js फाइलें बनाएं -

File: support.js

console.log("Child Process " + process.argv[2] + " executed." );

File: master.js

const fs = require('fs');
const child_process = require('child_process');
 
for(var i = 0; i<3; i++) {
   var workerProcess = child_process.spawn('node', ['support.js', i]);

   workerProcess.stdout.on('data', function (data) {
      console.log('stdout: ' + data);
   });

   workerProcess.stderr.on('data', function (data) {
      console.log('stderr: ' + data);
   });

   workerProcess.on('close', function (code) {
      console.log('child process exited with code ' + code);
   });
}

अब परिणाम देखने के लिए मास्टर दौड़ें-

$ node master.js

आउटपुट सत्यापित करें। सर्वर शुरू हो गया है

stdout: Child Process 0 executed.

child process exited with code 0
stdout: Child Process 1 executed.

stdout: Child Process 2 executed.

child process exited with code 0
child process exited with code 0

कांटा () विधि

child_process.fork विधि नोड प्रक्रियाओं को बनाने के लिए स्पॉन () का एक विशेष मामला है। इसके निम्नलिखित हस्ताक्षर हैं -

child_process.fork(modulePath[, args][, options])

मापदंडों

यहाँ प्रयुक्त मापदंडों का वर्णन है -

  • modulePath (स्ट्रिंग) बच्चे में चलाने के लिए मॉड्यूल।

  • args (ऐरे) स्ट्रिंग तर्कों की सूची

  • options (ऑब्जेक्ट) में निम्नलिखित विकल्पों में से एक या अधिक शामिल हो सकते हैं -

    • cwd (स्ट्रिंग) बच्चे की प्रक्रिया की वर्तमान कार्यशील निर्देशिका।

    • env (ऑब्जेक्ट) पर्यावरण कुंजी-मूल्य जोड़े।

    • execPath (स्ट्रिंग) बच्चे की प्रक्रिया बनाने के लिए उपयोग किए जाने वाले निष्पादन योग्य।

    • execArgv (एरे) स्ट्रिंग तर्कों की सूची निष्पादन योग्य (डिफ़ॉल्ट: process.execArgv) को दी गई।

    • silent (बूलियन) यदि बच्चे के सच्चे, स्टडिन, स्टडआउट, और स्टडर को माता-पिता के पास ले जाया जाएगा, अन्यथा वे माता-पिता से विरासत में मिलेंगे, स्पॉन के लिए "पाइप" और "इनहेरिट" विकल्प देखें। विवरण (डिफ़ॉल्ट गलत है)।

    • uid (संख्या) प्रक्रिया की उपयोगकर्ता पहचान सेट करता है।

    • gid (संख्या) प्रक्रिया की समूह पहचान सेट करता है।

कांटा विधि एक ऑब्जेक्ट को एक सामान्य चाइल्डप्रोसेस उदाहरण में सभी विधियों के अलावा अंतर्निहित संचार चैनल के साथ देता है।

उदाहरण

Support.js और master.js नाम की दो js फाइलें बनाएं -

File: support.js

console.log("Child Process " + process.argv[2] + " executed." );

File: master.js

const fs = require('fs');
const child_process = require('child_process');
 
for(var i=0; i<3; i++) {
   var worker_process = child_process.fork("support.js", [i]);	

   worker_process.on('close', function (code) {
      console.log('child process exited with code ' + code);
   });
}

अब परिणाम देखने के लिए मास्टर दौड़ें-

$ node master.js

आउटपुट सत्यापित करें। सर्वर शुरू हो गया है।

Child Process 0 executed.
Child Process 1 executed.
Child Process 2 executed.
child process exited with code 0
child process exited with code 0
child process exited with code 0