Ako vytvoriť podriadené procesy v Node.js

Ako Vytvorit Podriadene Procesy V Node Js



Počas programovania v „ node.js “, jediný proces nie je nikdy efektívny pri zvládaní narastajúceho pracovného zaťaženia aplikácie. Preto môžu nastať určité situácie, keď vývojár potrebuje vytvoriť nové procesy, pracovať s dlhodobými úlohami a umožniť interakciu s operačným systémom. Dá sa to dosiahnuť vytvorením podriadených procesov na využitie viacerých procesov, čím sa škáluje aplikácia Node.

Tento zápis vysvetľuje nižšie uvedený obsah:







Čo je to detský proces?

Podradený proces zodpovedá procesu vytvorenému prostredníctvom iného procesu, t. j. rodiča. Node.js poskytuje „ child_process ” modul, ktorý zabezpečuje efektívnu komunikáciu medzi podriadenými procesmi. Tento modul tiež pomáha pri vyvolaní funkcií operačného systému vykonaním akéhokoľvek systémového príkazu v rámci podriadeného procesu.



Ako vytvoriť podriadené procesy v Node.js?

Dieťa spracováva v „ node.js “ možno vytvoriť pomocou nižšie uvedených prístupov:



  • spawn() “Metóda.
  • vidlička() “Metóda.
  • exec() “Metóda.
  • execFile() “Metóda.

Prístup 1: Vytváranie podriadených procesov v node.js pomocou metódy „spawn()“.

' spawn() ” vygeneruje cmdlet v novom procese s využitím poskytnutého cmdlet a argumentov príkazového riadka. Inštancia ChildProcess aplikuje/implementuje EventEmitter API, ktoré umožňuje registrovať obslužné programy pre udalosti na podriadených objektoch. Tieto udalosti zahŕňajú ukončenie, odpojenie, chybu, správu a zatvorenie.





Syntax

child_process. spawn ( cmdlet [ , args ] [ , možnosti ] )

V tejto syntaxi:



  • cmdlet: Na vykonanie je potrebný reťazec, ktorý je rutinou cmdlet.
  • argumenty: Odkazuje na zoznam argumentov reťazca. Predvolená hodnota je nulové pole.
  • ' možnosti ” môže byť “shell”, ktorý má booleovskú hodnotu. Je to tak, že ak je „ pravda “, cmdlet sa spustí z prostredia shellu. Predvolená hodnota je „ falošný “, čo neznamená žiadnu škrupinu. Predvolene, ' spawn() ” nevytvára/negeneruje shell na spustenie cmdlet, preto je dôležité odovzdať ho ako „možnosť“ pri prístupe k podriadenému procesu.

Návratová hodnota: Táto metóda načíta objekt ChildProcess.

Nasleduje ukážka vytvorenia podriadeného procesu:

konšt { spawn } = vyžadovať ( 'child_process' ) ;

konšt dieťa = spawn ( 'ty' , [ 'D: \S ETUPS' ] , { škrupina : pravda } ) ;

dieťa. stdout . na ( 'data' , ( údajov ) => {

konzoly. log ( `stdout : $ { údajov } ` ) ;

} ) ;

dieťa. stderr . na ( 'data' , ( údajov ) => {

konzoly. chyba ( `stderr : $ { údajov } ` ) ;

} ) ;

dieťa. na ( 'Zavrieť' , ( kód ) => {

konzoly. log ( `podriadený proces bol ukončený s kódom $ { kód } ` ) ;

} ) ;

V tomto bloku kódu:

  • V prvom rade zahrňte „ child_process ” modul na vytvorenie podriadeného procesu.
  • Potom vytvorte podriadený proces na zobrazenie obsahu v zadanej ceste, napr. D:\SETUPS “.
  • Nakoniec, „ Zavrieť ” udalosť sa vyvolá, keď sa ukončí celý podriadený proces a na konzole sa zobrazí správa o ukončení.

Výkon

Tu spustite nasledujúci cmdlet na spustenie kódu a zobrazenie obsahu v cieľovej ceste:

uzol tep. js

Prístup 2: Vytváranie podriadených procesov v node.js pomocou metódy „fork()“.

Táto metóda je spojená s „ spawn() “, kde sa komunikácia medzi detským a rodičovským procesom môže uskutočňovať prostredníctvom „ poslať () “.

' vidlička() ” metóda oddeľuje zložité úlohy výpočtu od slučky udalostí (hlavnej). Túto metódu možno použiť na prístup k viacerým podriadeným procesom, ale môže ovplyvniť celkový výkon, pretože každý proces má svoju vlastnú pamäť.

Syntax

child_process. vidlička ( mdpath [ , args ] [ , možnosti ] )

Podľa tejto syntaxe:

  • mdpath ” berie reťazec, ktorý predstavuje modul, ktorý sa má spustiť v potomkovi.
  • args ” odkazuje na zoznam argumentov reťazca.
  • možnosti “ môže byť „execPath“, „env“, „CWD“, „detached“ a „execArgv“.

Návratová hodnota: Táto metóda načíta inštanciu ChildProcess.

Kód (nadradený proces)

Teraz si prejdite nižšie uvedený blok kódu, ktorý umožňuje komunikáciu medzi nadradenými a podriadenými procesmi pomocou „ poslať () “ metóda:

konšt cp = vyžadovať ( 'child_process' ) ;

nechať dieťa = cp. vidlička ( __dirname + '/fork2.js' ) ;

dieťa. na ( 'správa' , funkcia ( X ) {

konzoly. log ( 'Rodičovský proces má:' , X ) ;

} ) ;

dieťa. poslať ( { Ahoj : „z rodičovského procesu“ } ) ;

dieťa. na ( 'Zavrieť' , ( kód ) => {

konzoly. log ( `podriadený proces bol ukončený s kódom $ { kód } ` ) ;

} ) ;

V tomto kóde:

  • Podobne začleňte aj „ child_process ” modul na vytvorenie podriadeného procesu.
  • Teraz zadajte cestu podriadeného procesu cez „ vidlička() “.
  • Nakoniec zobrazte správu predstavujúcu nadradený proces prostredníctvom „ poslať () ” a zobrazte prípadné chyby.

Kód (podradený proces)

Nasledujúci kódový súbor, napr. fork2.js “ predstavuje podradený proces, ktorý tiež odosiela správu pomocou „ poslať () “, takto:

proces. na ( 'správa' , funkcia ( m ) {

konzoly. log ( 'Podriadený proces má:' , m ) ;

} ) ;

proces. poslať ( { Ahoj : „proces od dieťaťa“ } ) ;

Výkon

Teraz spustite nižšie uvedený cmdlet a spustite kód:

node forkchild. js

Z tohto výstupu je potvrdené, že komunikácia procesu rodič-dieťa prebieha primerane.

Prístup 3: Vytváranie podriadených procesov v node.js pomocou metódy „exec()“.

' exec() ” najprv vytvorí shell a potom spustí cmdlet. Táto metóda sa použije na získanie všetkých adresárov.

Syntax

child_process. exec ( cmdlet [ , možnosti ] [ , zavolaj späť ] )

V danej syntaxi:

  • cmdlet ” berie reťazec, ktorý predstavuje príkaz na vykonanie s argumentmi oddelenými medzerami.
  • ' možnosti “ zahŕňajú „cwd“, „kódovanie“, „shell“ atď.
  • ' zavolaj späť ” funkcia sa vyvolá, keď sa proces/operácia skončí.

Návratová hodnota

Táto metóda načíta inštanciu ChildProcess.

Teraz prejdite na kód, ktorý uvádza počet adresárov:

konšt { exec } = vyžadovať ( 'child_process' ) ;
exec ( 'dir | nájsť /c /v ''' , ( chyba, stdout, stderr ) => {
ak ( chyba ) {
konzoly. chyba ( `Exec chyba : $ { chyba } ` ) ;
vrátiť ;
}
konzoly. log ( `stdout : číslo adresárov -> $ { stdout } ` ) ;
ak ( stderr != '' )
konzoly. chyba ( `stderr : $ { stderr } ` ) ;
} ) ;

Do tohto útržku kódu zahrňte „ child_process ” modul na vytváranie/vytváranie podradených procesov. Potom sa vysporiadajte s výnimkami/chybami a zobrazte celkový počet adresárov v aktuálnom pracovnom adresári.

Výkon

Na spustenie kódu vykonajte nasledujúci kód:

uzol execchild. js

V tomto výstupe možno predpokladať, že sa zobrazí celkový počet adresárov v aktuálnom pracovnom adresári.

Prístup 4: Vytváranie podriadených procesov v node.js pomocou metódy execFile().

V ' execFile() “, cieľový spustiteľný súbor sa vytvorí priamo vo forme nového procesu, preto je efektívnejší ako „ exec() “. Táto metóda vytvára vytvorené „ execchild.js ” vo forme nového procesu.

Syntax

child_process. execFile ( názov súboru [ , args ] [ , možnosti ] [ , zavolaj späť ] )

V danej syntaxi:

  • názov súboru “ berie reťazec, ktorý predstavuje názov súboru alebo cestu na spustenie.
  • args ” zodpovedá zoznamu argumentov reťazca.
  • ' možnosti “ zahŕňajú „cwd“, „kódovanie“, „shell“ atď.
  • ' zavolaj späť ” funkcia sa vyvolá, keď sa proces skončí. Argumenty funkcie môžu byť error, stdout atď.

Návratová hodnota

Táto metóda tiež načíta inštanciu ChildProcess.

Teraz zvážte nasledujúci kód, ktorý vytvorí cieľový spustiteľný súbor, ako nový proces:

konšt { execFile } = vyžadovať ( 'child_process' ) ;
konšt X = execFile ( 'node' , [ 'execchild.js' ] ,
( chyba, stdout, stderr ) => {
ak ( chyba ) {
hodiť chyba ;
}
konzoly. log ( stdout ) ;
} ) ;

Na základe týchto riadkov kódu použite nasledujúce kroky:

  • Opakujte diskutovaný postup na zahrnutie „ child_process “.
  • V ďalšom kroku použite „ execFile() ” spôsob, ktorý vytvorí zadaný spustiteľný súbor (o ktorom sme hovorili v predchádzajúcom prístupe) ako nový proces, čím sa zobrazí zoznam všetkých adresárov v pracovnom adresári.

Výkon

Spustite nižšie uvedený cmdlet na spustenie kódu:

execfile uzla. js

V tomto výsledku je možné overiť, že zadaný spustiteľný súbor sa vytvorí a zobrazí sa počet adresárov.

Záver

Podriadené procesy v Node.js možno vytvoriť pomocou súboru „ spawn() “ metóda, “ vidlička() “ metóda, “ exec() “ alebo “ execFile() “. Tieto prístupy vytvárajú podriadený proces, umožňujú komunikáciu rodičovského a podriadeného procesu alebo vypisujú zoznamy adresárov v aktuálnom pracovnom adresári (priamo alebo prostredníctvom vytvorenia cieľového spustiteľného súboru).