Maison  >  Article  >  interface Web  >  Utilisez PM2 pour gérer le partage de processus nodejs

Utilisez PM2 pour gérer le partage de processus nodejs

小云云
小云云original
2018-01-03 13:44:101680parcourir

pm2 est un gestionnaire de processus pour les applications Node avec fonction d'équilibrage de charge. Cet article présente principalement l'explication détaillée de l'utilisation de PM2 pour gérer les processus nodejs. L'éditeur pense que c'est plutôt bon, je vais donc le partager avec vous maintenant et le donner. comme référence. Suivons l'éditeur pour y jeter un œil, j'espère que cela pourra aider tout le monde.

PM2 est parfait lorsque vous souhaitez que votre code autonome utilise tous les processeurs de tous les serveurs et garantisse que le processus est toujours actif avec des recharges de 0 seconde.

Il est très adapté à la structure IaaS, mais ne l'utilisez pas pour une solution PaaS (la solution Paas sera développée plus tard).

Par rapport à l'utilisation de node index.js, avantages :

1 Une fenêtre de commande peut gérer plusieurs processus de serveur de nœuds. La commande node nécessite plusieurs processus pour ouvrir plusieurs fenêtres.

2 Fermez la fenêtre de commande et le processus de nœud s'exécutera toujours. Une fois la commande node exécutée et la fenêtre fermée, le processus est également fermé.

Installez d'abord PM2

npm install -g pm2

Deuxièmement, utilisez pm2 pour démarrer index.js

pm2 start index.js --name tank

--name tank doit donner un nom à ce processus

Trois autres commandes pm2

安装
npm install -g pm2

用法
$ npm install pm2 -g   # 命令行安装 pm2 
$ pm2 start app.js -i 4 #后台运行pm2,启动4个app.js 
                # 也可以把'max' 参数传递给 start
                # 正确的进程数目依赖于Cpu的核心数目
$ pm2 start app.js --name my-api # 命名进程
$ pm2 list        # 显示所有进程状态
$ pm2 monit       # 监视所有进程
$ pm2 logs        # 显示所有进程日志
$ pm2 stop all      # 停止所有进程
$ pm2 restart all    # 重启所有进程
$ pm2 reload all     # 0秒停机重载进程 (用于 NETWORKED 进程)
$ pm2 stop 0       # 停止指定的进程
$ pm2 restart 0     # 重启指定的进程
$ pm2 startup      # 产生 init 脚本 保持进程活着
$ pm2 web        # 运行健壮的 computer API endpoint (http://localhost:9615)
$ pm2 delete 0      # 杀死指定的进程
$ pm2 delete all     # 杀死全部进程

运行进程的不同方式:
$ pm2 start app.js -i max # 根据有效CPU数目启动最大进程数目
$ pm2 start app.js -i 3   # 启动3个进程
$ pm2 start app.js -x    #用fork模式启动 app.js 而不是使用 cluster
$ pm2 start app.js -x -- -a 23  # 用fork模式启动 app.js 并且传递参数 (-a 23)
$ pm2 start app.js --name serverone # 启动一个进程并把它命名为 serverone
$ pm2 stop serverone    # 停止 serverone 进程
$ pm2 start app.json    # 启动进程, 在 app.json里设置选项
$ pm2 start app.js -i max -- -a 23          #在--之后给 app.js 传递参数
$ pm2 start app.js -i max -e err.log -o out.log # 启动 并 生成一个配置文件
你也可以执行用其他语言编写的app ( fork 模式):
$ pm2 start my-bash-script.sh  -x --interpreter bash
$ pm2 start my-python-script.py -x --interpreter python

0秒停机重载:
这项功能允许你重新载入代码而不用失去请求连接。
注意:
仅能用于web应用
运行于Node 0.11.x版本
运行于 cluster 模式(默认模式)
$ pm2 reload all

CoffeeScript:
$ pm2 start my_app.coffee #这就是全部

PM2准备好为产品级服务了吗?
只需在你的服务器上测试
$ git clone https://github.com/Unitech/pm2.git
$ cd pm2
$ npm install # 或者 npm install --dev ,如果devDependencies 没有安装
$ npm test

Recommandations associées :

Comment utiliser PM2 pour faciliter le clustering Node.js

Tutoriel PM2.5 Data Collection_PHP

Architecture de Gestionnaire de processus PHP FastCGI PHP-FPM

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn