1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
|
L'exemple ci-dessus fournit un service de calcul de séquence de Fibonacci. Étant donné que ce calcul prend beaucoup de temps et est monothread, lorsqu'il y a plusieurs requêtes en même temps, une seule peut être traitée via child_process.fork(. ) Ce problème peut être résolu
Voici un exemple tiré du site officiel, à travers lequel vous pouvez mieux comprendre la fonction de fork()
1 2 3 4 5 6 |
|
Les résultats de l'exécution de l'extrait de code ci-dessus :
1 2 |
|
Le contenu de sub.js est le suivant :
1 2 3 4 |
|
Dans le sous-processus, l'objet processus a une méthode send(), et il publiera le message à chaque fois qu'il reçoit un message.
Ce qui est un peu déroutant, c'est que le message envoyé par child.send() est reçu par la méthode process.on(), et le message envoyé par process.send(). () est reçue par la méthode child.on()
En nous référant à cet exemple, nous pouvons améliorer le premier service qui fournit des données de Fibonacci afin que chaque requête ait un nouveau processus distinct à gérer
1 2 3 4 5 6 7 8 9 10 11 |
|
fibonacci-calc.js
1 2 3 4 5 6 7 8 9 10 |
|
Après avoir démarré le service, visitez http://localhost:8080/9 pour calculer la valeur de la séquence de Fibonacci de 9
Le ci-dessus se trouve cet article. C'est tout. J'espère que vous l'aimerez tous.
Pour plus d'articles liés à l'implémentation multi-processus de child_process dans Node.js, veuillez faire attention au site Web PHP chinois !