Kaip sukurti antrinius procesus Node.js

Kaip Sukurti Antrinius Procesus Node Js



Kai programuojate „ node.js “, vienas procesas niekada nėra efektyvus norint susidoroti su didėjančiu programos darbo krūviu. Todėl gali būti tam tikrų situacijų, kai kūrėjui reikia kurti naujus procesus, dirbti su ilgalaikėmis užduotimis ir įgalinti sąveiką su operacine sistema. Tai galima pasiekti sukuriant antrinius procesus, kad būtų galima naudoti kelis procesus, taip padidinant mazgo programos mastelį.

Šiame rašte paaiškinamas toliau pateiktas turinys:







Kas yra vaiko procesas?

Antrinis procesas atitinka procesą, sukurtą naudojant kitą procesą, t. y. pirminį. Node.js pateikia „ vaikas_procesas “ modulis, užtikrinantis efektyvų bendravimą tarp vaiko procesų. Be to, šis modulis padeda iškviesti operacinės sistemos funkcijas, vykdant bet kurią sistemos komandą antriniame procese.



Kaip sukurti antrinius procesus Node.js?

Vaikas apdoroja „ node.js “ galima sukurti taikant toliau nurodytus metodus:



  • neršti () “ metodas.
  • šakutė () “ metodas.
  • vykdyti () “ metodas.
  • execFile() “ metodas.

1 metodas: Vaikų procesų kūrimas node.js naudojant „spawn()“ metodą

neršti () “ metodas generuoja cmdlet naujame procese, naudodamas pateiktą cmdlet ir komandinės eilutės argumentus. ChildProcess egzempliorius taiko / įgyvendina EventEmitter API, kuri leidžia registruoti įvykių antriniuose objektuose tvarkykles. Šie įvykiai apima išėjimą, atsijungimą, klaidą, pranešimą ir uždarymą.





Sintaksė

vaikas_procesas. neršti ( cmdlet [ , args ] [ , galimybės ] )

Šioje sintaksėje:



  • cmdlet: Vykdyti reikia eilutės, kuri yra cmdlet.
  • args: Tai nurodo eilutės argumentų sąrašą. Numatytoji reikšmė yra nulinis masyvas.
  • galimybės “ gali būti „apvalkalas“, kuris turi Būlio reikšmę. Taip yra, jei tai yra „ tiesa “, cmdlet vykdomas iš apvalkalo. Numatytoji reikšmė yra ' klaidinga “, o tai nereiškia, kad nėra apvalkalo. Pagal numatytuosius nustatymus „ neršti () “ nesukuria / negeneruoja apvalkalo cmdlet paleisti, todėl labai svarbu perduoti jį kaip „parinktį“ pasiekiant antrinį procesą.

Grąžinimo vertė: Šis metodas nuskaito ChildProcess objektą.

Toliau pateikiamas vaiko proceso kūrimo demonstravimas:

konst { neršti } = reikalauti ( 'vaiko_procesas' ) ;

konst vaikas = neršti ( 'tu' , [ 'D: \S ETUPS ] , { apvalkalas : tiesa } ) ;

vaikas. stdout . įjungta ( 'duomenys' , ( duomenis ) => {

konsolė. žurnalas ( `stdout : $ { duomenis } ` ) ;

} ) ;

vaikas. stderr . įjungta ( 'duomenys' , ( duomenis ) => {

konsolė. klaida ( `stderr : $ { duomenis } ` ) ;

} ) ;

vaikas. įjungta ( 'Uždaryti' , ( kodas ) => {

konsolė. žurnalas ( `antrasis procesas baigtas naudojant kodą $ { kodas } ` ) ;

} ) ;

Šiame kodo bloke:

  • Visų pirma įtraukite „ vaikas_procesas “ modulis, skirtas vaiko procesui sukurti.
  • Po to sukurkite antrinį procesą, kad turinys būtų rodomas nurodytu keliu, t. y. „ D:\SETUPS “.
  • Galiausiai „ Uždaryti “ įvykis iškviečiamas, kai išjungiamas visas antrinis procesas ir konsolėje rodomas išėjimo pranešimas.

Išvestis

Čia paleiskite šią cmdlet, kad paleistumėte kodą ir būtų rodomas turinys tiksliniame kelyje:

mazgo temp. js

2 metodas: Antrinių procesų kūrimas node.js naudojant „fork()“ metodą

Šis metodas yra susijęs su ' neršti () “ metodas, kai bendravimas tarp vaiko ir tėvų procesai gali būti vykdomas per „ siųsti () “ metodas.

šakutė () “ metodas atskiria sudėtingas skaičiavimo užduotis nuo įvykių ciklo (pagrindinės). Šis metodas gali būti naudojamas norint pasiekti kelis antrinius procesus, tačiau jis gali turėti įtakos bendram našumui, nes kiekvienas procesas turi savo atmintį.

Sintaksė

vaikas_procesas. šakutė ( mdpath [ , args ] [ , galimybės ] )

Pagal šią sintaksę:

  • mdpath “ paima eilutę, vaizduojančią modulį, kurį reikia vykdyti vaikui.
  • args “ nurodo eilutės argumentų sąrašą.
  • galimybės “ gali būti „execPath“, „env“, „CWD“, „detached“ ir „execArgv“.

Grąžinimo vertė: Šis metodas nuskaito ChildProcess egzempliorių.

Kodas (tėvų procesas)

Dabar pereikite prie toliau pateikto kodo bloko, kuris įgalina ryšį tarp tėvų ir vaiko procesų naudojant „ siųsti () “ metodas:

konst cp = reikalauti ( 'vaiko_procesas' ) ;

tegul vaikas = cp. šakutė ( __dirname + „/fork2.js“ ) ;

vaikas. įjungta ( 'žinutė' , funkcija ( x ) {

konsolė. žurnalas ( „Tėvų procesas gavo:“ , x ) ;

} ) ;

vaikas. siųsti ( { Sveiki : „iš tėvų proceso“ } ) ;

vaikas. įjungta ( 'Uždaryti' , ( kodas ) => {

konsolė. žurnalas ( `antrasis procesas baigtas naudojant kodą $ { kodas } ` ) ;

} ) ;

Šiame kode:

  • Taip pat įtraukite „ vaikas_procesas “ modulis, skirtas vaiko procesui sukurti.
  • Dabar nurodykite vaiko proceso kelią naudodami „ šakutė () “ metodas.
  • Galiausiai, naudodami „ siųsti () “ metodą ir parodykite klaidą (-as), jei tokių yra.

Kodas (antrinis procesas)

Šis kodo failas, ty ' fork2.js “ reiškia antrinį procesą, kuris taip pat siunčia pranešimą naudodamas „ siųsti () “ metodu taip:

procesas. įjungta ( 'žinutė' , funkcija ( m ) {

konsolė. žurnalas ( 'Vaiko procesas gavo:' , m ) ;

} ) ;

procesas. siųsti ( { Sveiki : 'iš vaiko proceso' } ) ;

Išvestis

Dabar paleiskite toliau pateiktą cmdlet, kad paleistumėte kodą:

mazgas forkchild. js

Iš šio rezultato patvirtinama, kad tėvų ir vaikų proceso komunikacija vykdoma tinkamai.

3 metodas: Antrinių procesų kūrimas node.js naudojant „exec()“ metodą

vykdyti () “ metodas pirmiausia sukuria apvalkalą ir paleidžia cmdlet. Šis metodas bus naudojamas norint nuskaityti visus katalogus.

Sintaksė

vaikas_procesas. vykdytojas ( cmdlet [ , galimybės ] [ , perskambink ] )

Nurodytoje sintaksėje:

  • cmdlet “ paima eilutę, vaizduojančią komandą, kurią reikia vykdyti su tarpais atskirtais argumentais.
  • galimybės “ apima „cwd“, „kodavimą“, „apvalkalą“ ir kt.
  • perskambink “ funkcija iškviečiama, kai procesas / operacija baigiasi.

Grąžinimo vertė

Šis metodas nuskaito ChildProcess egzempliorių.

Dabar pereikite prie kodo, kuriame nurodytas katalogų skaičius:

konst { vykdytojas } = reikalauti ( 'vaiko_procesas' ) ;
vykdytojas ( 'rež. | rasti /c /v ''' , ( klaida, stdout, stderr ) => {
jeigu ( klaida ) {
konsolė. klaida ( `vykdymo klaida : $ { klaida } ` ) ;
grąžinti ;
}
konsolė. žurnalas ( `stdout : Skaičius katalogų -> $ { stdout } ` ) ;
jeigu ( stderr != '' )
konsolė. klaida ( `stderr : $ { stderr } ` ) ;
} ) ;

Į šį kodo fragmentą įtraukite „ vaikas_procesas “ modulis, skirtas kurti/padaryti antrinius procesus. Po to susidorokite su iškilusiomis išimtimis / klaidomis ir parodykite bendrą katalogų skaičių dabartiniame darbiniame kataloge.

Išvestis

Vykdykite šį kodą, kad paleistumėte kodą:

mazgo execchild. js

Šiame išvestyje galima numanyti, kad rodomi visi dabartinio darbo katalogo katalogai.

4 metodas: Antrinių procesų kūrimas node.js naudojant execFile() metodą

Viduje ' execFile() “ metodą, tikslinis vykdomasis failas sukuriamas tiesiogiai naujo proceso forma, todėl jis yra efektyvesnis nei „ vykdyti () “ metodas. Šis metodas sukuria sukurtą ' execchild.js “ failą naujo proceso forma.

Sintaksė

vaikas_procesas. execFile ( failo pavadinimas [ , args ] [ , galimybės ] [ , perskambink ] )

Nurodytoje sintaksėje:

  • failo pavadinimas “ paima eilutę, nurodančią failo pavadinimą arba vykdymo kelią.
  • args “ atitinka eilutės argumentų sąrašą.
  • galimybės “ apima „cwd“, „kodavimą“, „apvalkalą“ ir kt.
  • perskambink “ funkcija iškviečiama, kai procesas baigiasi. Funkcijos argumentai gali būti klaida, stdout ir kt.

Grąžinimo vertė

Šis metodas taip pat nuskaito ChildProcess egzempliorių.

Dabar apsvarstykite šį kodą, kuris sukuria tikslinį vykdomąjį failą kaip naują procesą:

konst { execFile } = reikalauti ( 'vaiko_procesas' ) ;
konst x = execFile ( 'mazgas' , [ „execchild.js“ ] ,
( klaida, stdout, stderr ) => {
jeigu ( klaida ) {
mesti klaida ;
}
konsolė. žurnalas ( stdout ) ;
} ) ;

Remdamiesi šiomis kodo eilutėmis, atlikite šiuos veiksmus:

  • Pakartokite aptartą procedūrą įtraukdami „ vaikas_procesas “ modulis.
  • Kitame veiksme pritaikykite „ execFile() “ metodas, kuris sukuria nurodytą vykdomąjį failą (aptartą ankstesniame požiūryje) kaip naują procesą, taip išvardijant visus darbinio katalogo katalogus.

Išvestis

Vykdykite toliau pateiktą cmdlet, kad paleistumėte kodą:

mazgo vykdymo failas. js

Šiame rezultate galima patikrinti, ar nurodytas vykdomasis failas yra sukurtas ir rodomas katalogų skaičius.

Išvada

Antrinius procesus Node.js galima sukurti naudojant „ neršti () “ metodas, „ šakutė () “ metodas, „ vykdyti () “ metodas arba „ execFile() “ metodas. Šie metodai sukuria antrinį procesą, įgalina tėvų ir vaikų procesų ryšį arba pateikia katalogų sąrašą dabartiniame darbiniame kataloge (tiesiogiai arba sukuriant tikslinį vykdomąjį failą).