Nginx+PM2+Node.js

1、pm2简介#

   pm2(process manager)是一个进程管理工具,维护一个进程列表,可以用它来管理你的node进程,负责所有正在运行的进程,并查看node进程的状态,也支持性能监控,负载均衡等功能。

   1.1、使用pm2管理的node程序的好处#

  1. 监听文件变化,自动重启程序
  2. 支持性能监控
  3. 负载均衡
  4. 程序崩溃自动重启
  5. 服务器重新启动时自动重新启动
  6. 自动化部署项目

2、pm2安装与使用#

2.1、全局安装#

npm install pm2 -g 

2.2、常用命令#

相关命令echo $PATH

1
2
3
4
5
6
pm2 list      //进程列表
pm2 start 0   //0为进程id,也可以为进程名
pm2 restart 0 //重启
pm2 stop 0    //停止
pm2 delete 0 //删除
pm2 show 0    //查看详情

进程卡死处理

1
2
lsof -i:port   //查看相关端口
kill -9 pid    //杀死对应进程

  

  • 启动一个node程序 
pm2 start start.js   

 

  • 启动进程并指定应用的程序名
pm2 start app.js --name application1
  • 集群模式启动
// -i 表示 number-instances 实例数量
// max 表示 PM2将自动检测可用CPU的数量 可以自己指定数量
pm2 start start.js -i max

  • 添加进程监视
// 在文件改变的时候会重新启动程序
pm2 start app.js --name start --watch

  • 列出所有进程

    pm2 list
    pm2 ls // 简写
  • 从进程列表中删除进程

    // pm2 delete [appname] | id
    pm2 delete app  // 指定进程名删除
    pm2 delete 0    // 指定进程id删除 
  • 删除进程列表中所有进程

    pm2 delete all
  • 查看某个进程具体情况

    pm2 describe app
  • 查看进程的资源消耗情况
    pm2 monit
  • 重启进程

     pm2 restart app // 重启指定名称的进程
     pm2 restart all // 重启所有进程 
  • 查看进程日志

     pm2 logs app    // 查看该名称进程的日志
     pm2 logs all    // 查看所有进程的日志 
  • 设置pm2开机自启

开启启动设置,此处是CentOS系统,其他系统替换最后一个选项(可选项:ubuntu, centos, redhat, gentoo, systemd, darwin, amazon)

   pm2 startup centos 

然后按照提示需要输入的命令进行输入

最后保存设置

pm2 save

3、通过pm2配置文件来自动部署项目#

确保服务器安装了pm2,没有安装的话先安装

npm install pm2 -g

 #

3.1 在项目根目录下新建一个 deploy.yaml 文件#

复制代码
复制代码
# deploy.yaml
apps:
  - script: ./start.js       # 入口文件
    name: 'app'              # 程序名称
    env:                     # 环境变量
      COMMON_VARIABLE: true
    env_production:
      NODE_ENV: production

deploy:                     # 部署脚本
  production:               # 生产环境
    user: lentoo            # 服务器的用户名
    host: 192.168.2.166     # 服务器的ip地址
    port: 22                # ssh端口
    ref: origin/master      # 要拉取的git分支
    ssh_options: StrictHostKeyChecking=no # SSH 公钥检查
    repo: https://github.com/**.git # 远程仓库地址
    path: /home              # 拉取到服务器某个目录下
    pre-deploy: git fetch --all # 部署前执行
    post-deploy: npm install &&  pm2 reload deploy.yaml --env production # 部署后执行
    env:
      NODE_ENV: production
复制代码
复制代码

3.2、配置git的ssh免密认证#

  1. 在服务器中生成rsa公钥和私钥,当前是 centos7 下进行

  2. 前提服务器要安装git,没有安装的先安装git,已安装的跳过

    yum –y install git
  3. 生成秘钥

     ssh-keygen -t rsa -C "xxx@xxx.com"

    在~/.ssh目录下有 id_rsa和 id_rsa.pub两个文件,其中id_rsa.pub文件里存放的即是公钥key。

  4. 登录到GitHub,点击右上方的头像,选择settings ,点击Add SSH key,把id_rsa.pub的内容复制到里面即可。

3.3 使用pm2部署项目#

每次部署前先将本地的代码提交到远程git仓库

  • 首次部署
pm2 deploy deploy.yaml production setup 

部署完成后,既可登陆服务器查看配置的目录下是否从git上拉取了项目

  • 再次部署
pm2 deploy deploy.yaml production upddate

3.4 该部署流程同样适用前端项目#

如vue-cli的项目,自动部署到服务器,自动执行npm run build 命令,生成的dist目录,指定到nginx的静态文件目录下。

4、可能会遇到的坑#

  • 在window系统下 vscode的命令行程序,以及powershell执行部署的命令时,出现部署失败
pm2 deploy deploy.yaml production setup  
 
解决方案:使用git命令行来执行

反向代理配置方式#

1
2
3
4
5
6
7
8
server {
  listen 80;
  server_name www.luckybing.top;
 
  location / {
     proxy_pass http://127.0.0.1:3000;
  }
}

使用PM2永动机启动Node.js项目,再使用nginx做反向代理,简直完美。

因为node.js程序监听的是服务器端口,使用nginx做反向代理,就可以任意配置你的二级域名来访问你的程序

负载均衡配置方式#

1
2
3
4
5
6
upstream b.com {
      ip_hash;
      server  192.168.5.150:80;
      server  192.168.5.151:80;
      server  192.168.5.151:8080;
}  

Https配置#

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
server{
        listen 443 ssl;
        server_name xxx.xxx.com;
        ssl_certificate /root/certs/test.crt;
        ssl_certificate_key /root/certs/test.key;
        ssl_session_cache shared:SSL:1m;
        ssl_session_timeout 5m;
        ssl_ciphers HIGH:!aNULL:!MD5;
        ssl_prefer_server_ciphers on;
        location /{
                proxy_pass http://localhost:3000;
                proxy_set_header Host $host;
                proxy_http_version 1.1;
                proxy_set_header Upgrade $http_upgrade;
                proxy_set_header Connection "upgrade";
                proxy_read_timeout 86400;
        }
}

Nginx解决跨域问题#

1
2
3
4
5
6
7
8
9
10
11
12
13
14
server{
        listen  80;
        server_name test.abc.com;
 
        location / {
            proxy_pass http://127.0.0.1:8080;
 
            add_header Access-Control-Allow-Origin *;
            add_header Access-Control-Allow-Headers Content-Type;
            add_header Access-Control-Allow-Methods POST;
            add_header Access-Control-Allow-Methods GET;
        }
 
}
posted @   Tipsy(微醺)  阅读(170)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示
more_horiz
keyboard_arrow_up light_mode palette
选择主题
menu
点击右上角即可分享
微信分享提示