PM2是什么

PM2(Process Manager 2 )是具有内置负载均衡器的Node.js应用程序的生产运行时和进程管理器。 它允许您永久保持应用程序活跃,无需停机即可重新加载它们,并促进常见的Devops任务。

PM2特性

日志管理:应用程序日志保存在服务器的硬盘中~/.pm2/logs/

负载均衡:PM2可以通过创建共享同一服务器端口的多个子进程来扩展您的应用程序。这样做还允许您以零秒停机时间重新启动应用程序。

终端监控:可以在终端中监控您的应用程序并检查应用程序运行状况(CPU使用率,使用的内存,请求/分钟等)。

SSH部署:自动部署,避免逐个在所有服务器中进行ssh。

静态服务:支持静态服务器功能

多平台支持:适用于Linux(稳定)和macOS(稳定)和Windows(稳定)

PM2安装

先安装nodejs,下载路径:http://nodejs.cn/#download

然后全局安装pm2

#npm方式

npm install pm2 -g

#yarn方式

yarn global add pm2

#linux

apt update && apt install sudo curl && curl -sL https://raw.githubusercontent.com/Unitech/pm2/master/packager/setup.deb.sh | sudo -E bash -

PM2命令方式

启动服务

pm2 start app.js //启动app.js应用

pm2 start app.js --name demo //启动应用并设置name

pm2 start app.sh //脚本启动

停止服务

pm2 stop all //停止所有应用

pm2 stop [AppName] //根据应用名停止指定应用

pm2 stop [ID] //根据应用id停止指定应用

删除应用

pm2 delete all //关闭并删除应用

pm2 delete [AppName] //根据应用名关闭并删除应用

pm2 delete [ID] //根据应用ID关闭并删除应用

创建开机自启动

pm2 startup

更新PM2

pm2 updatePM2

pm2 update

监听模式

pm2 start app.js --watch //当文件发生变化,自动重启

静态服务器

pm2 serve ./dist 9090 //将目录dist作为静态服务器根目录,端口为9090

启用群集模式(自动负载均衡)

//max 表示PM2将自动检测可用CPU的数量并运行尽可能多的进程

//max可以自定义,如果是4核CPU,设置为2者占用2个

pm2 start app.js -i max

重新启动

pm2 restart app.js //同时杀死并重启所有进程。短时间内服务不可用。生成环境推荐使用reload

0秒停机重新加载

pm2 reload app.js //重新启动所有进程,始终保持至少一个进程在运行

pm2 gracefulReload all //优雅地以群集模式重新加载所有应用程序

查看启动列表

pm2 list

查看每个应用程序占用情况

pm2 monit

显示应用程序所有信息

pm2 show [Name] //根据name查看

pm2 show [ID] //根据id查看

日志查看

pm2 logs //查看所有应用日志

pm2 logs [Name] //根据指定应用名查看应用日志

pm2 logs [ID] //根据指定应用ID查看应用日志

保存当前应用列表

pm2 save

重启保存的应用列表

pm2 resurrect

清除保存的应用列表

pm2 cleardump

保存并恢复PM2进程

pm2 update

PM2配置文件方式

生成示例配置文件

pm2 ecosystem //生成一个示例JSON配置文件

pm2 init

配置文件示例(实际使用自行删除)

module.exports = {

apps : [{

name : 'API', //应用名

script : 'app.js', //应用文件位置

env: {

PM2_SERVE_PATH: ".", //静态服务路径

PM2_SERVE_PORT: 8080, //静态服务器访问端口

NODE_ENV: 'development' //启动默认模式

},

env_production : {

NODE_ENV: 'production' //使用production模式 pm2 start ecosystem.config.js --env production

},

instances:"max", //将应用程序分布在所有CPU核心上,可以是整数或负数

watch:true, //监听模式

output: './out.log', //指定日志标准输出文件及位置

error: './error.log', //错误输出日志文件及位置,pm2 install pm2-logrotate进行日志文件拆分

merge_logs: true, //集群情况下,可以合并日志

log_type:"json", //日志类型

log_date_format: "DD-MM-YYYY", //日志日期记录格式

}],

deploy : {

production : {

user : 'node', //ssh 用户

host : '212.83.163.1', //ssh 地址

ref : 'origin/master', //GIT远程/分支

repo : 'git@github.com:repo.git', //git地址

path : '/var/www/production', //服务器文件路径

post-deploy : 'npm install && pm2 reload ecosystem.config.js --env production' //部署后的动作

}

}

};

PM2 管理可执行命令行程序可以使用pm2 start -x './frpc' -n frp -- -c ./frpc.ini来启动,注意 -x 是说明程序是可以执行程序,-- 后边的参数是传给命令行。

PM2 管理 Python 类的程序,可以使用pm2 start server.py --interpreter python -n ssr -- -p 8888 -m aes-256-cfb -O auth_aes128_md5 -o tls1.2_ticket_auth_compatible -k password, 里边的 --interpreter 参数可以设置程序类型,-- 后边的参数是传给程序的。

命令示例大全:

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

linux pm2功能说明,PM2介绍及简易使用手册相关推荐

  1. atmega32u4 Linux,arduino整合wifi功能系列arduinoyun介绍(1)

    arduino整合wifi功能系列arduinoyun介绍 Arduino 2013年5月刚发布了一款新系列的无线产品arduinoYUN, 它合并了 Arduino 架构和 Linux 系统. Ar ...

  2. Linux网络常用工具分类介绍

    Linux网络命令较多,单纯的介绍网络命令的用法也没什么意思.本文将常见的网络命令进行分类,并做出思维导图,对每个分类的命令选择性的介绍其作用.常见选项和用法举例.BTW,不建议记住所有命令,了解一下 ...

  3. Window VNC远程控制LINUX:VNC详细配置介绍

    Window VNC远程控制LINUX:VNC详细配置介绍 //---------------------------------------vnc linux下的详细配置 1.VNC的启动/停止/重 ...

  4. Netty入门笔记-Linux网络I/O模型介绍

    在之前的博客中并没有将关于Netty的知识系统的总结起来.从这篇博客开始就将关于Netty的有关知识点总结起来顺便提升自己的分析问题的能力,通过博客分享的形式将学习的知识点形成体系,希望也可以帮助大家 ...

  5. Linux内存管理:kmemcheck介绍

    目录 Linux内核内存管理第3部分. Linux内核中的kmemcheck简介 该kmemcheck机制在Linux内核中的实现 结论 链接 读原文:<Linux内存管理:kmemcheck介 ...

  6. linux端口转发_详解Linux网桥功能--概念、工作机制、相关命令及实例说明

    概述 在说Linux网桥之前,先介绍几个概念,有助于对网桥的功能及实现有更深的理解. 一个交换网络的逻辑图: 1. 冲突域 一个冲突域由所有能够看到同一个冲突或者被该冲突涉及到的设备组成.以太网使用C ...

  7. linux动态追踪神器——Strace实例介绍【转】

    Strace是Linux下一款通用的进程动态跟踪工具,用来追踪程序执行时的系统调用和所接收的信号.其应用方法如下图(部分). 首先,简单说说它的使用参数,Strace的参数包括输出参数.过滤参数.统计 ...

  8. 优麒麟系统安装MySQL_优麒麟Linux(Ubuntu Kylin)简易安装手册

    优麒麟( (Ubuntu Kylin )18.04  简易 安装手册 优麒麟(Ubuntu Kylin)18.04 是优麒麟开源操作系统的第三个长线支持版本,为方便用户下载安装和 使用,特制作本简易安 ...

  9. Linux 常用命令~命令行介绍

    目录 一.Linux 命令行概述 1.Linux 命令行的重要作用 2.Linux 命令行介绍 3.Linux 命令行的启动及退出 4.Linux 命令行提示符 5.命令行的历史记录和编辑 6.命令行 ...

  10. Linux驱动开发-proc接口介绍

    1. 前言 Linux系统上的/proc目录是一种文件系统,即proc文件系统. 与其它常见的文件系统不同的是,/proc是一种伪文件系统(也即虚拟文件系统),存储的是当前内核运行状态的一系列特殊文件 ...

最新文章

  1. 蓝牙 socket 建立不了_蓝牙电话之PBAP同步电话簿的安卓实现
  2. Spring3向Spring4升级过程中quartz修改
  3. “.Net 社区虚拟大会”(dotnetConf) 2016 Day 2 Keynote: Miguel de Icaza
  4. Oracle入门(十四.20)之创建DML触发器:第一部分
  5. mysql error 1114,mysql error 1114 table is full 处理分享
  6. mysql最小费用最大流问题_图论-网络流之最小费用最大流问题
  7. efcore调用函数_EF Core 3.1 执行sql语句的几种方法
  8. androidannotations 在android studio中的使用
  9. ubuntu linux 系统搭建我的世界基岩版 私服我的世界服务器
  10. UGUI源码之绘制初探
  11. 计算机专业理论试题答案最新,2017年计算机一级考试题库及答案
  12. 群智能优化算法学习规划
  13. 零基础程序员自学编程的6种方法,你知道吗?
  14. 用计算机求算术平方根,6.1用计算机计算算术平方根.ppt
  15. 关于程序员的职业规划分析
  16. Celery介绍---手机短信异步发送
  17. 一、使用JDK的keytool生成JKS以及获取JKS的信息
  18. 关于显示webpack不是内部或外部命令问题的解决方法
  19. paddlehub创意赛《王者四大美女--红昭愿》
  20. 实现微信向多好友定时发送信息

热门文章

  1. Cookie、LocalStorage 与 SessionStorage的区别
  2. sql cast函数_数据分析面试必备——SQL你掌握的怎么样?
  3. Linux系统p4vasp使用教程,[分享]一个详细的p4vasp安装指南 - 计算模拟 - 小木虫 - 学术 科研 互动社区...
  4. python turtle输出坐标_如何在Python/turtle中使用坐标列表绘制形状
  5. 安卓手机状态栏显示秒_如何让状态栏时间精确到秒显示
  6. async 和 defer
  7. [Swift]LeetCode528. 按权重随机选择 | Random Pick with Weight
  8. C#实体更新指定的字段
  9. 敏捷开发总结(2)开发过程活动
  10. [我研究]看最新会议相关论文感想