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 )合作贡献而成。