PM2相关基础知识

PM2相关基础知识,第1张

1.什么是pm2: pm2是一个进程管理工具,维护一个进程列表,用它来管理node进程,负责所有运行的进程并查看node进程的状态,也支持性能监控,负载均衡等功能。

2.pm2与其他工具对比信息:其他工具拥有的特性都支持

3.特性

①后台运行:普通的启动方式 node index.js,关闭终端就结束进程,但pm2关闭终端后仍可在后端运行

②自动重启:可以监听某些文件改动,自动重启(岂不是可以利用这个来做自动部署?)

③停止不稳定的进程:限制不稳定的重启次数,到达上限就停止进程

④0秒停机重启集群模式下(什么是集群模式?),可以达到重启时不停止服务(怎么做到的)

⑤简单日志管理:pm2可以收集日志,并有插件配合管理

⑥自动负载均衡:cluster(集群)模式下,会自动使用轮询 的方式达到负载均衡,从而减轻服务器的压力

⑦提供实时的接口:pm2插件提供实时的接口,返回服务器与进程的信息

⑧集成管理:有多个进程,不同环境可以统一配置,方便管理

4.基础用法

①启动进程:pm2 start app.js

②停止/删除/重启进程:pm2 stop/delete/restart app_name|app_id|all

集群模式下,restart中断服务,而reload不会

③查看所有的进程:pm2 list/ls/status

名词解释:

1.集群模式:( Cluster 集群模式):

例如Redis上加入了cluster模式,实现了分布式存储,就是每台Redis节点上存储不同的内容

形象解释:

    单体架构:类似全栈工程师一体化服务,啥都做

    集群:也是什么都做,但是不同的是多了一个全栈工程师负担你的工作量,均匀分配,减轻压力

    高可用:当集群中其中一个服务宕机后,并不影响另一个服务的工作,只是压力会大一点,这个现象叫做高可用

    分布式:前端后端明确分工,搭配合作就叫分布式

总而言之,集群是物理形态(一般是物理集中,统一管理的)而分布式是个工作方式。

简介

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

下面就对PM2进行入门性的介绍,基本涵盖了PM2的常用的功能和配置。

node项目线上环境需求

1、服务器稳定性;

2、充分利用服务器硬件资源,提高性能;

3、线上日志记录;

PM2功能

1、进程守护,系统奔溃自动重启;

2、启动多进程,充分利用cpu和内存;

3、自带日志记录功能;

运行项目

name:应用程序名称

cwd:应用程序所在的目录

script:应用程序的脚本路径

log_date_format:日志打印时间格式配置

error_file:自定义应用程序的错误日志文件

out_file:自定义应用程序日志文件

pid_file:自定义应用程序的pid文件

instances:多进程配置

min_uptime:最小运行时间,这里设置的是60s即如果应用程序在60s内退出,pm2会认为程序异常退出,此时触发重启max_restarts设置数量

max_restarts:设置应用程序异常退出重启的次数,默认15次(从0开始计数)

cron_restart:定时启动,解决重启能解决的问题

watch:是否启用监控模式,默认是false。如果设置成true,当应用程序变动时,pm2会自动重载。这里也可以设置你要监控的文件。

merge_logs:

exec_interpreter:应用程序的脚本类型,这里使用的shell,默认是nodejs

exec_mode:应用程序启动模式,这里设置的是cluster_mode(集群),默认是fork

autorestart:启用/禁用应用程序崩溃或退出时自动重启

vizion:启用/禁用vizion特性(版本控制)

基本使用

PM2 项目启动,但是无法访问:

pm2 kill 杀死所有进程,重新启动

1、操作系统限制了单个进程的的大小,node在32位系统占用1.6内存,当个进程是受限制;

2、一个进程奔溃了,其他进程不受影响

3、无法充分利用硬件资源;

多进程之间内存无法共享

利用redis对多进程进行共享数据

pm2官网: https://pm2.keymetrics.io/


欢迎分享,转载请注明来源:夏雨云

原文地址:https://www.xiayuyun.com/zonghe/165011.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-03-24
下一篇2023-03-24

发表评论

登录后才能评论

评论列表(0条)

    保存