每天分享一点运维小知识---pm2工具

简介: 每天分享一点运维小知识---pm2工具

前言

对于后台进程的管理,常用的工具是crontab,可用于两种场景:定时任务和常驻脚本。关于常驻脚本,今天介绍一款更好用的工具:pm2,基于nodejs开发的进程管理器,适用于后台常驻脚本管理,同时对node网络应用有自建负载均衡功能。官方的说法,pm2 是一个带有负载均衡功能的Node应用的进程管理器,个人认为,并不准确,因为pm2支持多种语言,只是对于除node之外的其他进程无负载均衡的能力。


一、pm2特点

说一些pm2有哪些优点好处呢?


支持进程行为配置 ,即可以通过配置,实现对pm2管理应用的一些基础属性更新修改,如应用名称,启动模式等;


支持集群模式,支持负载均衡,但因采用nodejs的cluster模块实现,仅适用于nodejs进程;


支持source map,此项针对js, source map文件是js源文件的信息文件,里面存储着源文件的位置信息;


支持热重启;


支持部署工作流,pm2可依据测试环境和线上环境自动部署到不同的服务器,同时运行在不同配置下;


支持监听重启,在文件更新等情况下可实现进程自动重启;


支持linux的startup进程启动,startup是指系统boot, 进程自启动,如centos的chkconfig;


日志管理,两种日志,pm2系统日志与管理的进程日志,默认会把进程的控制台输出记录到日志中;


命令自动补全功能,个人感觉这个功能意义不大,而且尝试了一下,没有原生的linux命令自动补全反应敏捷;


监控功能,pm2 monit监控cpu和memory使用情况,keymetrics监控更为详细;


支持开发调试模式,非后台运行,pm2-dev start ;


支持pm2模块开发,实现pm2的功能扩展;


keymetrics监控,比pm2 monit监控更为详细友好,通过web页面展示;


最大内存重启,设置最大内存限制,超过限制自动重启;


编程API,提供API供开发者通过编程方式灵活管理进程;


以上简要概述了pm2进程管理工具的特点。


二、pm2命令详解

pm2常用命令

常用命令通常都是比较简单。下面列举一些pm2常用的管理命令


pm2 start  [options] 启动指定应用,如pm2 start index.js --name httpServer;


pm2 stop [options] 停止指定应用,如pm2 stop httpServer;

也可以执行他目录下得 pm2-start.sh 脚本里面用. pm2-start.sh 执行输入0就可以关闭在执行得脚本


pm2 reload|restart [options] 重启指定应用,如pm2 restart httpServer;


pm2 show [options] 显示指定应用详情,如pm2 show httpServer;


pm2 delete [options] 删除指定应用,如pm2 delete httpServer,如果修改应用配置行为,最好先删除应用后,重新启动方才生效,如修改脚本入口文件;


pm2 kill 杀掉pm2管理的所有进程;


pm2 logs 查看指定应用的日志,即标准输出和标准错误;



  • pm2 monit 监控各个应用进程cpu和memory使用情况


三、如何安装一个pm2?

pm2是一个进程管理工具,可以用它来管理node进程,并查看node进程的状态,当然也支持性能监控,进程守护,负载均衡等功能,在前端和nodejs的世界中用的很多。

pm2是基于npm进行安装的,在安装pm2之前要先安装npm


3.1安装node.js

若服务器上已有node.js,可跳过此步,可以通过此命令查看有无node.js


node -v

pm2服务依赖node.js服务,若服务器上无node.js服务,需要先安装node.js; linux安装node.js

这里得node.js你可以去官方下载你自己系统对应得版本 http://nodejs.cn/download/


wget https://nodejs.org/dist/vv16.17.0/node-vv16.17.0-linux-x64.tar.xz     // 下载
tar xf  node-vv16.17.0-linux-x64.tar.xz              // 解压
cd node-vv16.17.0-linux-x64                          // 进入解压目录
./bin/node -v                                       // 执行node命令 查看版本
v16.17.0

这里可以软链接一下方便以后得使用


ln -s /usr/local/node/bin/node   /usr/bin       //这里得地址依据你自己安装的node地址自行修改
ln -s /usr/local/node/bin/npm /usr/bin 
或者ln -s  $nodejs_hom2/bin/npm   /usr/local/bin/ 
   ln -s  $nodejs_hom2/bin/node   /usr/local/bin/

这时你直接输入node -v就可以显示你安装node对应的版本号了到这里node安装结束




3.2安装pm2

全局安装:


npm install -g pm2

安装完之后会将pm2模块安装在$nodejs_home/lib/node_modules/pm2下,然后将pm2做软连接


ln -s /usr/local/node/bin/pm2 /usr/bin
ln -s $nodejs_hom2/bin/pm2   /usr/local/bin/  //建立软连接
pm2 -v                                        //查看pm2版本
4.5.0

这里如果你不折到pm2具体安装在哪了你可以


which pm2   //查询安装路径



这时pm2也可以用了





3.3离线安装pm2

如果服务器无法联网,那么也就无法使用全局安装的命令进行在线安装,需要进行离线安装,最简单的方法是,找到一台可以在线安装的服务器,进行pm2的安装,安装完成后,利用如下命令,直接进入到pm2的安装路径


cd $(npm config get prefix)/lib/node_modules   //进入node.js的node_modules路径
ls                                             //查看
npm  pm2

然后将这个目录下的pm2打包,上传至需要离线安装pm2服务器的对应目录


tar xzvf pm2.tar.gz    //解压
ln -s  $nodejs_hom2/lib/node_modules/pm2/bin/pm2   /usr/local/bin/   //建立软连接
pm2 -v                 //查看pm2版本
4.5.0


相关实践学习
部署高可用架构
本场景主要介绍如何使用云服务器ECS、负载均衡SLB、云数据库RDS和数据传输服务产品来部署多可用区高可用架构。
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
6月前
|
运维 Shell Linux
Ansible自动化运维工具之常用模块使用实战(5)
Ansible自动化运维工具之常用模块使用实战(5)
|
6月前
|
运维 Kubernetes 网络安全
Ansible自动化运维工具之主机管理与自定义配置文件(2)
Ansible自动化运维工具之主机管理与自定义配置文件(2)
|
6月前
|
存储 运维 Linux
Ansible自动化运维工具安装入门,看这一篇就够了(1)
Ansible自动化运维工具安装入门,看这一篇就够了(1)
|
7月前
|
运维 大数据 Shell
自动化运维工具—Ansible-1
自动化运维工具—Ansible
106 0
|
7月前
|
缓存 运维 Linux
Linux(CentOS)运维脚本工具集合
Linux(CentOS)运维脚本工具集合
148 2
|
6月前
|
运维 应用服务中间件 网络安全
Ansible自动化运维工具之解决SSH连接使用明文密码问题(4)
Ansible自动化运维工具之解决SSH连接使用明文密码问题(4)
|
6天前
|
存储 运维 Shell
Ansible自动化运维工具安装和基本使用
Ansible 是一款无代理的IT自动化工具,通过SSH连接目标主机执行配置管理、应用部署和云端管理任务。它使用YAML编写的Playbook定义任务,核心组件包括Playbook、模块、主机清单、变量等。Ansible的优势在于易用、功能强大、无须在目标主机安装额外软件,并且开源。安装过程涉及配置网络源、yum安装和SSH密钥设置。通过定义主机清单和使用模块进行通信测试,确保连接成功。
Ansible自动化运维工具安装和基本使用
|
6天前
|
机器学习/深度学习 运维 网络协议
运维工程师必会工具(Nmap和TCPdump)
运维工程师必会工具(Nmap和TCPdump)
|
1月前
|
人工智能 运维 Prometheus
现代运维中的自动化工具与挑战
随着信息技术的不断发展,现代运维工作日益复杂且关键。本文将探讨现代运维中自动化工具的应用与挑战,介绍各类自动化工具在提高效率、降低风险方面的作用,并讨论在实际应用中可能面临的问题与解决方法。
27 4
|
1月前
|
运维 负载均衡 监控
提升运维效率:自动化工具在云端环境中的应用
随着云计算技术的快速发展,运维工作面临着更加复杂和繁重的挑战。本文将探讨如何利用自动化工具在云端环境中提升运维效率,从而降低成本、减少人为错误,并实现更高水平的运维管理。