一文教你如何使用Node进程管理工具-pm2 环球头条

2023-04-25 10:37:38 | 来源:博客园
pm2 是什么

pm2 是一个守护进程管理工具,它能帮你守护和管理你的应用程序。通常一般会在服务上线的时候使用 pm2 进行管理。pm2 能做的其实有很多,比如监听文件改动自动重启,统一管理多个进程,内置的负载均衡,日志系统等等,下面就让我们看下 pm2 是如何使用的吧

pm2 基本命令

首先我们先创建一个简单的 node 服务,新建文件夹执行npm init,然后装 pm2

npm i pm2 -g

新建 index.js 和 index2.js,写两个简单的 http 服务,然后用 pm2 进行管理


【资料图】

//index.jslet http = require("http");let server = http.createServer();server.on("request", function (req, res) {  console.log("------------------enter");  res.write("hello juejin");  res.end();});server.listen(3000, function () {  console.log(`服务器启动成功,通过http://localhost:3000/进行访问`);});
//index2.jslet http = require("http");let server = http.createServer();server.on("request", function (req, res) {  console.log("------------------enter2");  res.write("hello juejin2");  res.end();});server.listen(3001, function () {  console.log(`服务器启动成功,通过http://localhost:3001/进行访问`);});

接下来我们将使用 pm2 的第一个命令: pm2 start index.jspm2 start index2.js分别启动这两个个程序

当然如果你想指定进程名字可以这样: pm2 start -n test index.js,如果你想监听文件改动可以加--watch等等

访问http://localhost:3000/

执行pm2 log可以看到我们打印的日志

pm2 的命令还有很多,下面列举几个

停止 1 个/多个/所有程序 pm2 stop id/id1 id2 id3/all杀死 1 个/多个/所有程序 pm2 delete id/id1 id2 id3/all重启 1 个/多个/所有程序 pm2 restart id/id1 id2 id3/all启动并查看日志 pm2 start api.js --attach列出应用程序 pm2 list查看监控面板 pm2 monit查看程序数据 pm2 show [id]负载均衡

我们都知道 NodeJS 是一个异步单线程语言,倘若不做任何处理直接部署到服务器上,那么它也只能使用服务器的一个线程,这样是非常浪费性能的。

使用 pm2 只需一个命令就能让我们的程序充分利用服务器的 CPU,拿 index.js 为例:pm2 start index -i max,比如我的电脑是 10 核 20 线程,它就会开 20 个线程

当然如果你想指定多少线程可以直接将 max 改成你想开的线程数 pm2 start index -i 3

配置文件

上面的例子我们都是使用命令行进行管理的,这样其实挺不方便的,好在 pm2 提供了配置文件的形式。

我们直接使用命令pm2 init simple即可生成一个简单的配置文件ecosystem.config.js,修改一下让它指向我们的两个服务

module.exports = {  apps: [    {      name: "index",      script: "./index.js",    },    {      name: "index2",      script: "./index2.js",    },  ],};

然后我们将原先的进程都 kill 掉,执行pm2 start ecosystem.config.js,同样的我们的两个服务都被启动了

下面列举一些配置项ecosystem.config.js

module.exports = {  apps: [    {      name: "index", //name      script: "./index.js", //相对于pm2 start 的相对路径      cwd: "", //要启动的应用程序的目录      instances: 2, //要启动实例的数量,就是上面提到的负载      watch: true, //是否启动监听      env: { NODE_ENV: "development" }, //将出现在您的应用程序中的 env 变量      env_xxx: {        NODE_ENV: "xxx", //使用pm2注入xxx变量进行切换      },      log_date_format: "YYYY-MM-DD HH:mm Z", //日志时间格式      error_file: "./log/index-error.log", //错误文件路径      out_file: "./log/index-out.log", //输出日志文件路径      max_restarts: 10, //最大重启数      restart_delay: 4000, //重启延迟时间ms      autorestart: true, //是否自动重启      cron_restart: "", //定时重启 使用cron表达式    },    {      name: "index2",      script: "./index2.js",    },  ],};
日志

日志对于后端排查错误是非常重要的,pm2 自带日志功能,比如我们在上面配置文件中配置了日志相关的参数

log_date_format: "YYYY-MM-DD HH:mm Z", //日志时间格式error_file: "./log/index-error.log", //错误文件路径out_file: "./log/index-out.log", //输出日志文件路径

当我们启动项目的时候,日志就会记录在 log 下

pm2 自带的日志功能是不支持日志分割的。随着时间的推移,日志文件会越来越大,不仅会影响性能,后期排查问题也十分麻烦,因此我们需要对日志进行分割。日志分割操作很简单,只需要安装pm2-logrotate插件即可,注意这里是 pm2 install

pm2 install pm2-logrotate

然后执行 pm2 conf 可以看到相关配置

解释一下相关含义

Compress:是否通过 gzip 压缩日志

max_size:单个日志文件的大小

retain:保留的日志文件个数

dateFormat:日志文件名中的日期格式,默认是 YYYY-MM-DD_HH-mm-ss

rotateModule:是否把 pm2 本身的日志也进行分割,

workerInterval:检查文件时间间隔

rotateInterval:设置强制分割,默认值是 0 0 * * *,意思是每天晚上 0 点分割,这里使用的是 corn 表达式,不会的可以搜索一下

如果我们想要配置也很简单,比如修改 max_size

pm2 set pm2-logrotate:max_size 1K

然后我们简单测试一下这个工具,我们先设置每个 log 文件最大 1kb

然后重启我们的项目

pm2 restart ecosystem.config.js

然后就会发现我们的日志被分割了

总结

pm2对于node服务的管理是十分方便的,文中提到的只是其中一部分,如果你想使用pm2管理你的服务的话可以到官网pm2.io/ 进行学习

关注公众号web前端进阶每日更新最新前端技术文章,你想要的都有!

上一篇 下一篇

相关新闻

一文教你如何使用Node进程管理工具-pm2 环球头条

【当前独家】杭州三批供地:滨江14.31亿元拔得头筹 成交楼面价15292元/平米

教育股快速拉升 中公教育大涨8% 学大教育、科德教育、传智教育、国新文化等纷纷冲高|最新资讯

天天热推荐:去年高校撤销专业925个,“绝版”学生、老师何去何从?

92只ST股预告全年业绩 17股净利预盈 今日聚焦

4月25日讯,目前国内外产区出现不同程度的干旱情况,新胶产出受到限制,原料价格小幅走高,给予胶价一定支撑

海外博主打卡太原地标 感受三晋千年历史文化

快播:电脑喇叭没有了怎么办_电脑喇叭没有声音怎么修复

世界讯息:中南建设去年归母净亏损91.7亿元,计提减值准备35.3亿元

环球快看点丨果然“锂”亏!新能源锂电池爆雷了!AI大牛股业绩也崩了

世界看点:“深蓝1号” 让大西洋鲑在黄海安家

天天精选!今日申购:巨能股份

昨夜江边春水生艨艟巨舰一毛轻翻译_昨夜江边春水生艨艟巨舰一毛轻

丹麦智库专家:自由贸易仍是实现全球繁荣快捷路径

河北大学经济学院研究生院_河北大学经济学院

最新新闻

一文教你如何使用Node进程管理工具-pm2 环球头条

【当前独家】杭州三批供地:滨江14.31亿元拔得头筹 成交楼面价15292元/平米

教育股快速拉升 中公教育大涨8% 学大教育、科德教育、传智教育、国新文化等纷纷冲高|最新资讯

天天热推荐:去年高校撤销专业925个,“绝版”学生、老师何去何从?

92只ST股预告全年业绩 17股净利预盈 今日聚焦

4月25日讯,目前国内外产区出现不同程度的干旱情况,新胶产出受到限制,原料价格小幅走高,给予胶价一定支撑

海外博主打卡太原地标 感受三晋千年历史文化

快播:电脑喇叭没有了怎么办_电脑喇叭没有声音怎么修复

世界讯息:中南建设去年归母净亏损91.7亿元,计提减值准备35.3亿元

环球快看点丨果然“锂”亏!新能源锂电池爆雷了!AI大牛股业绩也崩了

世界看点:“深蓝1号” 让大西洋鲑在黄海安家

天天精选!今日申购:巨能股份

昨夜江边春水生艨艟巨舰一毛轻翻译_昨夜江边春水生艨艟巨舰一毛轻

丹麦智库专家:自由贸易仍是实现全球繁荣快捷路径

河北大学经济学院研究生院_河北大学经济学院

天天速讯:赢销通移动销售管理云平台蒙牛 赢销通

我爸爸把我婶婶打成鼻骨骨折,轻微移位现在住在医院不出医院怎么办_快看点

上海贝岭:4月24日融资买入6724.58万元,融资融券余额9.12亿元-全球快播报

8月4号是不是黄道吉日(8月4号)

世界头条:华夏职业技术学院官网_华夏职业技术学院

印度宣称“人口实力全面超越中国”,却被德国人一幅漫画刺激到了

环球热资讯!如何将繁体字转换成简体字的方法_如何将繁体字转换成简体字

市场观潮|该如何看待“酒店刺客”现象 视讯

信阳市罗山法院:法官耐心换真心 解开心结促和谐-环球微速讯

每日看点!天子呼来不上船 自称臣是酒中仙说的是谁_天子呼来不上船自称臣是酒中仙指的是谁

欧央行官员“放鹰”:只有工资增速放缓,加息才会停止 全球快讯

天问二号已基本完成初样研制 预计2025年5月前后发射

MSI入围赛抽签出炉:BLG和越南GAM同组!网友:帮TES报仇吗? 当前视讯

曹字可以组什么词_曹的意思

贵州龙里:“四到位”推进普法强基走深走实