pm2开启node多线程

pm2简介

PM2是node进程管理工具,可以利用它来简化很多node应用管理的繁琐任务,如性能监控、自动重启、负载均衡等

pm2常用命令

$ pm2 start app.js # 启动app.js应用程序
$ pm2 start app.js -i 4 # cluster mode 模式启动4个app.js的应用实例
# 4个应用程序会自动进行负载均衡
$ pm2 start app.js --name="api" # 启动应用程序并命名为 "api"
$ pm2 start app.js --watch # 当文件变化时自动重启应用
$ pm2 start script.sh # 启动 bash 脚本
$ pm2 list # 列表 PM2 启动的所有的应用程序
$ pm2 monit # 显示每个应用程序的CPU和内存占用情况
$ pm2 show [app-name] # 显示应用程序的所有信息
$ pm2 logs # 显示所有应用程序的日志
$ pm2 logs [app-name] # 显示指定应用程序的日志
pm2 flush
$ pm2 stop all # 停止所有的应用程序
$ pm2 stop 0 # 停止 id为 0的指定应用程序
$ pm2 restart all # 重启所有应用
$ pm2 reload all # 重启 cluster mode下的所有应用
$ pm2 gracefulReload all # Graceful reload all apps in cluster mode
$ pm2 delete all # 关闭并删除所有应用
$ pm2 delete 0 # 删除指定应用 id 0
$ pm2 scale api 10 # 把名字叫api的应用扩展到10个实例
$ pm2 reset [app-name] # 重置重启数量
$ pm2 startup # 创建开机自启动命令
$ pm2 save # 保存当前应用列表
$ pm2 resurrect # 重新加载保存的应用列表
$ pm2 update # Save processes, kill PM2 and restore processes
$ pm2 generate # Generate a sample json configuration file
pm2 start app.js --node-args="--max-old-space-size=1024"

简单测试

开启服务

创建服务端脚本server.js,开启一个最简单的node服务

//server.js
const http = require('http')

http.createServer((req, res) => {
    for (let i = 0; i < 1e7; i++) { }
    res.writeHead(200)
    res.end('hello')
}).listen(8888)

测试工具

测试工具用的是ab--ApacheBench
先是不开启多线程,命令行输入node server.js
然后用ab压测 -- ab -n 1000 -c 100 http://localhost:8888/,这条测试命令的意思是一共发送1000个请求,每秒100并发
得到如下结果

Server Software:
Server Hostname:        localhost
Server Port:            8888

Document Path:          /
Document Length:        5 bytes

Concurrency Level:      100
Time taken for tests:   8.641 seconds
Complete requests:      1000
Failed requests:        0
Total transferred:      80000 bytes
HTML transferred:       5000 bytes
Requests per second:    115.73 [#/sec] (mean)
Time per request:       864.071 [ms] (mean)
Time per request:       8.641 [ms] (mean, across all concurrent requests)
Transfer rate:          9.04 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    0   0.3      0       1
Processing:    38  827 170.3    815    1246
Waiting:       23  694 151.8    711     975
Total:         38  827 170.3    816    1246

Percentage of the requests served within a certain time (ms)
  50%    816
  66%    913
  75%    931
  80%    936
  90%   1012
  95%   1076
  98%   1230
  99%   1238
 100%   1246 (longest request)

可以看到服务端的QPS是115左右,再来使用pm2开启多线程。
npx pm2 start server.js -i max
如果执行这条指令之后发现只开启了一个线程或者是开启的是fork模式而不是cluster模式,可能是node版本所致,可以升级node至最新版本,或者执行命令npx pm2 kill,然后再执行上述命令。

┌──────────┬────┬─────────┬─────────┬───────┬────────┬─────────┬────────┬─────┬───────────┬─────────────┬──────────┐
│ App name │ id │ version │ mode    │ pid   │ status │ restart │ uptime │ cpu │ mem       │ user        │ watching │
├──────────┼────┼─────────┼─────────┼───────┼────────┼─────────┼────────┼─────┼───────────┼─────────────┼──────────┤
│ server   │ 0  │ N/A     │ cluster │ 13880 │ online │ 0       │ 2s     │ 0%  │ 30.1 MB   │ zhijieliang │ disabled │
│ server   │ 1  │ N/A     │ cluster │ 10572 │ online │ 0       │ 2s     │ 0%  │ 30.0 MB   │ zhijieliang │ disabled │
│ server   │ 2  │ N/A     │ cluster │ 8056  │ online │ 0       │ 1s     │ 0%  │ 29.9 MB   │ zhijieliang │ disabled │
│ server   │ 3  │ N/A     │ cluster │ 21452 │ online │ 0       │ 1s     │ 0%  │ 29.7 MB   │ zhijieliang │ disabled │
└──────────┴────┴─────────┴─────────┴───────┴────────┴─────────┴────────┴─────┴───────────┴─────────────┴──────────┘

我的电脑是4核的,所以开启了4个线程,再来看看测试结果,执行同样的压测命令。
ab -n 1000 -c 100 http://localhost:8888/

Server Software:
Server Hostname:        localhost
Server Port:            8888

Document Path:          /
Document Length:        5 bytes

Concurrency Level:      100
Time taken for tests:   4.022 seconds
Complete requests:      1000
Failed requests:        0
Total transferred:      80000 bytes
HTML transferred:       5000 bytes
Requests per second:    248.63 [#/sec] (mean)
Time per request:       402.203 [ms] (mean)
Time per request:       4.022 [ms] (mean, across all concurrent requests)
Transfer rate:          19.42 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    0   0.4      0       1
Processing:    25  381  64.8    397     432
Waiting:       17  380  65.0    397     432
Total:         25  381  64.8    398     432

Percentage of the requests served within a certain time (ms)
  50%    398
  66%    401
  75%    404
  80%    405
  90%    409
  95%    413
  98%    417
  99%    419
 100%    432 (longest request)

QPS提升了一倍左右。

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-15 17:46
暑期就挂了,秋招还有机会吗
大聪明777:研发提前批,14号刚开的,官网上面的配图上有写。提前批没过的话,秋招还可以投,不过前面的笔试/面试记录会被保留,供秋招参考
26届校招投递进展
点赞 评论 收藏
分享
来个厂收我吧:首先,市场侧求职我不是很懂。 但是,如果hr把这份简历给我,我会觉得求职人不适合做产品经理。 问题点: 1,简历的字体格式不统一,排版不尽如人意 2,重点不突出,建议参考star法则写个人经历 3,印尼官方货币名称为印度尼西亚卢比(IDR),且GMV690000印尼盾换算为305人民币,总成交额不高。 4,右上角的意向职位在发给其他公司时记得删除。 5,你所有的经历都是新媒体运营,但是你要投市场营销岗位,jd和简历不匹配,建议用AI+提示词,参照多个jd改一下经历内容。 修改建议: 1,统一字体(中文:思源黑体或微软雅黑,英文数字:time new romans),在word中通过表格进行排版(b站学) 2,校招个人经历权重:实习经历=创业经历(大创另算)>项目经历>实训经历>校园经历 3,请将项目经历时间顺序改为倒序,最新的放最上方。 4,求职方向不同,简历文字描述侧重点也需要不同。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务