Sådan opretter du underordnede processer i Node.js

Sadan Opretter Du Underordnede Processer I Node Js



Under programmering i ' node.js ”, er en enkelt proces aldrig effektiv til at klare den stigende arbejdsbyrde af applikationen. Derfor kan der være visse situationer, hvor udvikleren skal skabe nye processer, arbejde med langsigtede opgaver og muliggøre interaktion med operativsystemet. Dette kan opnås ved at oprette underordnede processer for at gøre brug af flere processer og derved skalere en Node-applikation.

Denne artikel forklarer indholdet nedenfor:







Hvad er en børneproces?

En underordnet proces svarer til en proces, der er oprettet via en anden proces, dvs. forældre. Node.js giver ' barn_proces ” modul som sikrer den effektive kommunikation mellem børneprocesserne. Dette modul hjælper også med at kalde operativsystemets funktioner ved at udføre en hvilken som helst systemkommando i en underordnet proces.



Hvordan oprettes underordnede processer i Node.js?

Barnet bearbejder i ' node.js ” kan oprettes via nedenstående fremgangsmåder:



  • spawn() ' Metode.
  • gaffel() ' Metode.
  • exec() ' Metode.
  • execFile() ' Metode.

Fremgangsmåde 1: Oprettelse af underordnede processer i node.js Via 'spawn()'-metoden

Det ' spawn() ”-metoden genererer en cmdlet i en ny proces ved at bruge den medfølgende cmdlet og kommandolinjeargumenterne. ChildProcess-instansen anvender/implementerer EventEmitter API, som gør det muligt at registrere handlere for hændelser på underordnede objekter. Disse hændelser omfatter exit, disconnect, error, message og close.





Syntaks

barn_proces. gyde ( cmdlet [ , args ] [ , muligheder ] )

I denne syntaks:



  • cmdlet: Det kræver en streng, som er cmdlet'en for at udføre.
  • argumenter: Det refererer til listen over strengargumenter. Standardværdien er et nul-array.
  • Det ' muligheder ” kan være en “skal”, der tager en boolsk værdi. Det er sådan, at hvis det er ' rigtigt ”, udføres cmdlet'en inde fra skallen. Standardværdien er ' falsk ” hvilket indebærer ingen skal. Som standard, ' spawn() ” opretter/genererer ikke en shell til at køre cmdlet’en, derfor er det afgørende at videregive den som en “mulighed”, mens du får adgang til den underordnede proces.

Returneringsværdi: Denne metode henter et ChildProcess-objekt.

Følgende er demonstrationen af ​​at skabe en børneproces:

konst { gyde } = kræve ( 'barneproces' ) ;

konst barn = gyde ( 'du' , [ 'D: \S ETUPS' ] , { skal : rigtigt } ) ;

barn. stdout . ( 'data' , ( data ) => {

konsol. log ( `stdout : $ { data } ` ) ;

} ) ;

barn. stderr . ( 'data' , ( data ) => {

konsol. fejl ( `stderr : $ { data } ` ) ;

} ) ;

barn. ( 'tæt' , ( kode ) => {

konsol. log ( `Underordnet proces afsluttet med kode $ { kode } ` ) ;

} ) ;

I denne kodeblok:

  • Først og fremmest skal du inkludere ' barn_proces ” modul til oprettelse af en underordnet proces.
  • Derefter afføder en underordnet proces til visning af indholdet i den angivne sti, dvs. ' D:\SETUPS ”.
  • Til sidst, ' tæt ” hændelse påkaldes, når hele den underordnede proces afsluttes, og afslutningsmeddelelsen vises på konsollen.

Produktion

Her skal du udføre følgende cmdlet for at køre koden og vise indholdet i målstien:

node temp. js

Fremgangsmåde 2: Oprettelse af underordnede processer i node.js ved hjælp af 'fork()'-metoden

Denne metode er forbundet med ' spawn() ” metode, hvor kommunikationen mellem barn og forældre processer kan udføres via ” sende() ” metode.

Det ' gaffel() ”-metoden adskiller de komplekse beregningsopgaver fra hændelsesløkken(main). Denne metode kan bruges til at få adgang til flere underordnede processer, men den kan påvirke den overordnede ydeevne, da hver proces har sin egen hukommelse.

Syntaks

barn_proces. gaffel ( mdpath [ , args ] [ , muligheder ] )

Ifølge denne syntaks:

  • mdpath ” tager en streng, der repræsenterer det modul, der skal udføres i barnet.
  • args ” refererer til en liste med strengargumenter.
  • muligheder ” kan være “execPath”, “env”, “CWD”, “detached” og “execArgv”.

Returneringsværdi: Denne metode henter en ChildProcess-instans.

Kode (forælderproces)

Gå nu gennem den nedenfor angivne kodeblok, der muliggør kommunikationen mellem forældre- og barnprocesserne ved hjælp af ' sende() ” metode:

konst cp = kræve ( 'barneproces' ) ;

lade barnet = cp. gaffel ( __dirnavn + '/fork2.js' ) ;

barn. ( 'besked' , funktion ( x ) {

konsol. log ( 'Overordnet proces fik:' , x ) ;

} ) ;

barn. sende ( { Hej : 'fra forældreproces' } ) ;

barn. ( 'tæt' , ( kode ) => {

konsol. log ( `Underordnet proces afsluttet med kode $ { kode } ` ) ;

} ) ;

I denne kode:

  • Ligeledes inkorporer ' barn_proces ” modul til oprettelse af en underordnet proces.
  • Angiv nu stien til den underordnede proces via ' gaffel() ” metode.
  • Til sidst skal du vise meddelelsen, der repræsenterer forældreprocessen via ' sende() ”-metoden og vis den/de viste fejl, hvis nogen.

Kode (underordnet proces)

Følgende kodefil, dvs. ' fork2.js ” repræsenterer den underordnede proces, der også sender beskeden ved hjælp af ” sende() ” metode, som følger:

behandle. ( 'besked' , funktion ( m ) {

konsol. log ( 'Børneproces fik:' , m ) ;

} ) ;

behandle. sende ( { Hej : 'fra børneproces' } ) ;

Produktion

Kør nu den nedenfor givne cmdlet for at udføre koden:

node gaffelbarn. js

Fra dette output bekræftes det, at forældre-barn proceskommunikationen udføres korrekt.

Fremgangsmåde 3: Oprettelse af underordnede processer i node.js ved hjælp af 'exec()'-metoden

Det ' exec() ”-metoden opretter først en shell og kører derefter cmdlet’en. Denne metode vil blive brugt til at hente de samlede mapper.

Syntaks

barn_proces. exec ( cmdlet [ , muligheder ] [ , ring tilbage ] )

I den givne syntaks:

  • cmdlet ” tager en streng, der repræsenterer kommandoen til at udføre med mellemrumsadskilte argumenter.
  • Det ' muligheder ' inkluderer 'cwd', 'encoding', 'shell' osv.
  • Det ' ring tilbage ”-funktionen aktiveres, når processen/handlingen afsluttes.

Returværdi

Denne metode henter en ChildProcess-instans.

Gå nu videre til koden, der viser antallet af mapper:

konst { exec } = kræve ( 'barneproces' ) ;
exec ( 'dir | find /c /v ''' , ( fejl, stdout, stderr ) => {
hvis ( fejl ) {
konsol. fejl ( 'exec fejl : $ { fejl } ` ) ;
Vend tilbage ;
}
konsol. log ( `stdout : Nummer af mapper -> $ { stdout } ` ) ;
hvis ( stderr != '' )
konsol. fejl ( `stderr : $ { stderr } ` ) ;
} ) ;

I dette kodestykke skal du inkludere ' barn_proces ” modul til at skabe/lave underordnede processer. Derefter skal du håndtere de opståede undtagelser/fejl og vise det samlede antal mapper i den aktuelle arbejdsmappe.

Produktion

Udfør følgende kode for at køre koden:

node execchild. js

I dette output kan det antydes, at de samlede mapper i den aktuelle arbejdsmappe vises.

Fremgangsmåde 4: Oprettelse af underordnede processer i node.js ved hjælp af execFile()-metoden

I ' execFile() ”-metoden affødes den eksekverbare målfil direkte i form af en ny proces, derfor er den mere effektiv end ” exec() ” metode. Denne metode afføder den oprettede ' execchild.js ” fil i form af en ny proces.

Syntaks

barn_proces. execFile ( filnavn [ , args ] [ , muligheder ] [ , ring tilbage ] )

I den givne syntaks:

  • filnavn ” tager en streng, der repræsenterer filens navn eller sti for at udføre.
  • args ” svarer til listen over strengargumenter.
  • Det ' muligheder ' inkluderer 'cwd', 'encoding', 'shell' osv.
  • Det ' ring tilbage ”-funktionen aktiveres, når processen afsluttes. Funktionsargumenterne kan være fejl, stdout osv.

Returværdi

Denne metode henter også en ChildProcess-instans.

Overvej nu følgende kode, der afføder den eksekverbare målfil som en ny proces:

konst { execFile } = kræve ( 'barneproces' ) ;
konst x = execFile ( 'node' , [ 'execchild.js' ] ,
( fejl, stdout, stderr ) => {
hvis ( fejl ) {
kaste fejl ;
}
konsol. log ( stdout ) ;
} ) ;

Baseret på disse kodelinjer skal du anvende følgende trin:

  • Gentag den diskuterede procedure for at inkludere ' barn_proces ” modul.
  • I det næste trin skal du anvende ' execFile() ”-metode, der afføder den angivne eksekverbare fil (diskuteret i den tidligere fremgangsmåde) som en ny proces, og derved viser de samlede mapper i arbejdsmappen.

Produktion

Udfør nedenstående cmdlet for at køre koden:

node execfile. js

I dette resultat kan det verificeres, at den angivne eksekverbare fil er skabt, og antallet af mapper vises.

Konklusion

De underordnede processer i Node.js kan oprettes via ' spawn() 'metoden, ' gaffel() 'metoden, ' exec() '-metoden eller ' execFile() ” metode. Disse fremgangsmåder afføder den underordnede proces, aktiverer kommunikationen mellem forældre- og underordnede processer eller lister mapperne i den aktuelle arbejdsmappe (direkte eller via dannelse af den eksekverbare målfil).