当前位置: 首页 > 工具软件 > pm2-webshell > 使用案例 >

pm2 start 带参数_pm2

孙子民
2023-12-01

PM2

1. pm2 是开源的基于Nodejs的进程管理器,包括守护进程、监控、日志的一整套完整的功能;

2. pm2 基本是node应用程序不二的守护进程选择;

3. 事实上,pm2并不仅仅可以启动node程序,对于一般的脚本程序同样可以胜任;

4. pm2 带有负载均衡功能,可以保持node应用进程永远运行在后台;

5. pm2 还有个非常强大的deploy功能,可以从本地直接部署线上网站。

node与PM2

1. 对于线上项目,如果直接通过 node app 来启动,如果报错了可能直接停止导致整个服务崩溃;

2. 一般监控 node 的几种进程管理方案:

1. supervisor: 一般用作开发环境的使用;

2. forever: 管理多个站点,一般每个站点的访问量不大的情况,不需要监控;

3. PM2: 网站的访问量比较大,需要完整的监控页面。

3. pm2的特性:

1. 内建负载均衡(使用 Node cluster 集群模块);

2. 后台运行;

3. 0 秒停机重载,维护升级时不需要停机;

4. 具有 Ubuntu 和 CentOS 的启动脚本;

5. 停止不稳定的进程(避免无限循环);

6. 控制台检测;

7. 提供 HTTP API;

8. 远程控制和实时的接口 API ( Nodejs 模块,允许和 PM2 进程管理器交互 )。

4. 全局安装:npm install -g pm2

PM2命令

1. 启动命令

1. pm2 start app.js:启动nodeJs应用,进程的默认名称为文件名app

2. pm2 start app.js --name mynode:启动node,并指定进程名称为mynode

3. pm2 start app.js -i max:根据有效CPU数目启动最大进程数目

4. pm2 start app.js -i 3:启动3个进程

5. pm2 start app.js --watch:实时监控的方式启动,app.js文件有变动时,pm2会自动reload

6. pm2 start app.js -x:用fork模式启动 app.js 而不是使用 cluster

7. pm2 start app.js -x -- -a 23:用fork模式启动 app.js 并且传递参数(-a 23)

8. pm2 start app.json:启动进程, 在 app.json里设置选项

9. pm2 start app.js -i max -- -a 23:在 -- 之后给 app.js 传递参数

10. pm2 start app.js -i max -e err.log -o out.log:启动并生成一个配置文件

2. 查看与监视进程

1. pm2 list:显示所有进程;

2. pm2 show 0,pm2 info 0:查看进程id为 0 的详细信息;

3. pm2 monit:进入监视页面,监视每个node进程的CPU和内存的使用情况。

3. 停止、删除进程

1. pm2 stop/delete 0:停止/删除id为 0 的进程;

2. pm2 stop/delete all:停止/删除所有进程。

4. 重启、重载

1. pm2 restart 0:重启id为 0 的进程;

2. pm2 restart all:重启所有进程;

3. pm2 reload 0:0秒停机重载id为 0 进程(用于 NETWORKED 进程);

4. pm2 reload all:重载所有进程。

5. 日志操作

1. pm2 logs:显示所有进程的日志;

2. pm2 logs 0:显示进程id为 0 的日志;

3. pm2 flush:清空所有日志文件;

4. pm2 reloadLogs:重载所有日志。

6. pm2 startup:产生 init 脚本,保持进程活着。

配置文件的方式启动:process.yml

apps:

- script: app.js

instances: 2

watch: true

env:

NODE_ENV: production

启动:pm2 start process.yml

pm2 kill 杀死PM2进程。

PM2启动nuxt

1. 打包nuxt项目:npm run build

2. pm2启动(Linux):

1. pm2 start npm --name mynuxt -- start

2. pm2 start npm --name "my-nuxt" -- run start

3. 默认情况下,用公网无法直接访问nuxt,必须配置nginx转发,才能访问

1. nuxt应用端口号为3000

2. nginx监听80端口,转发给3000端口,用公网访问80端口

4. 配置nuxt的package.json,直接通过公网访问nuxt应用

1. 在package.json中添加一个新的节点,与"dependencies"同级

"config": {

"nuxt": {

"host": "0.0.0.0",

"port": 3000

}

}

2. 服务器打开nuxt监听的端口3000,即可访问

ncc

ncc:类似于 gcc 的 Node.js 一键编译打包工具,一个简单的 CLI 工具,可以一键把一个 Node.js 项目编译打包成单个 JS 文件

npm i -g @zeit/ncc

ncc build app.js:开始打包,所有文件和引用都被打包编译到一个文件中,dist/index.js

ncc 受启发于 Go 语言的 build 功能(导出一个静态 ELF 可执行文件),目的也是输出一个 包含了所有依赖的独立可执行脚本。

ncc 本身基于 webpack 开发,项目也是由 ZEIT、webpack 作者( Tobias Koppers )、rollup 作者( Guy Bedford )合作贡献而成。

 类似资料: