Jenkins 远程启动nodejs失败,使用pm2守护Nodejs

一、概述

使用Jenkins 远程ssh到linux,使用命令:

ssh root@192.168.10.1 'cd /data/test;nohup npm start &'

 

发现linux服务器的node进程没有启动。但是本地执行命令:

cd /data/test;nohup npm start &

 是可以启动的。

 

具体原因,参考链接:

https://www.cnblogs.com/zhenbianshu/p/7152327.html

大致意思是,如果远程执行的命令,不是守护进程。即使加了nohup,关闭ssh连接后,当前用户启动的进程会全部终止。

因此,远程执行的命令,必须是守护进程才行。

 

二、pm2守护Nodejs

简介

pm2是nodejs的一个带有负载均衡功能的应用进程管理器的模块,类似有Supervisor,forever,用来进行进程管理。

 

安装

npm install pm2 -g

 

启动

pm2 start app.js
pm2 start app.js --name my-api #my-api为PM2进程名称
pm2 start app.js -i 0 #根据CPU核数启动进程个数
pm2 start app.js --watch #实时监控app.js的方式启动,当app.js文件有变动时,pm2会自动reload

 

查看进程

pm2 list
pm2 show 0 或者 # pm2 info 0 #查看进程详细信息,0为PM2进程id

 

停止

pm2 stop all #停止PM2列表中所有的进程
pm2 stop 0 #停止PM2列表中进程为0的进程

 

更多pm2命令,请参考链接:
https://www.jianshu.com/p/eb98e639f41e

 

三、pm2启动脚本

由于公司的Nodejs项目,比如test,它有4个服务,因此有4个app.js。

在package.json里面,有定义启动命令。比如:

"start:client": "cd ./client && npm start",

 

由于package.json里面有定义一些关联启动命令,因此直接用pm2启动4个app.js,会导致应用异常。

 

json格式

pm2 start npm -- start这条命令是pm2的万能命令,pm2 start ,就是这一系列命令中的最豪华命令。这个json我们可以理解为一个任务参数描述文件。通过这个json文件,我们把在命令行里面不好描述的各种参数放到一个json文件里面来

pm2 start <json>.json

 

pm2 start命令中的json格式详解

 

 

最精简版本

{
    "name": "manage",      //项目名称
    "script": "./bin/www", //要执行的脚本
    "cwd":"./",            //项目所在目录
}

 

执行shell文件版本

{
    "name": "manage",      //项目名称
    "script": "./bin/www.sh", //要执行的脚本
    "cwd":"./",            //项目所在目录
    "exec_interpreter": "bash",
}

 

实战例子demo

下面的test.json是公司项目

{
  "apps": [{
    "name": "test",  //项目名称
    "script": "test.sh",  //要执行的脚本
    "cwd": "/opt/script/",  //脚本所在目录
    "exec_interpreter": "bash",   //应用程序的脚本类型
    "exec_mode": "fork",
    "max_memory_restart": "1G",
    "autorestart": true,
    "node_args": [],
    "args": [],
    "env": {
      
    }
  }]
}

 

 说明:

  • apps:json结构,apps是一个数组,每一个数组成员就是对应一个pm2中运行的应用
  • 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特性(版本控制)

 

test.sh

#!/bin/bash

PROJECT_HOME=/data/test

source /etc/profile && cd $PROJECT_HOME;nohup /usr/bin/npm start &

 

当然,pm2的参数还有很多很多很多,这里仅仅是个范例demo,更多的参数可以点击这里,查看官方文档。

http://pm2.keymetrics.io/docs/usage/cluster-mode/

 

注意:当nodejs进程停止时,pm2会自动启动进程。

 

本文参考链接:

https://newsn.net/say/pm2-start-json.html

 

### 部署 Node.js 后端应用的最佳实践 部署 Node.js 后端应用程序涉及多个方面,包括环境准备、代码优化以及生产环境下的性能调优。以下是详细的说明: #### 1. 准备工作 在正式部署之前,需要确保本地开发环境中构建的应用程序能够正常运行于目标服务器上。通常情况下,在开发阶段,服务器会运行在 `localhost` 上[^3]。为了使应用能够在公网访问,需将其迁移到实际的远程主机。 #### 2. 使用包管理工具配置国内镜像源 如果项目依赖较多或者网络条件不佳,可以考虑切换至国内 NPM 镜像源以加速安装过程。执行命令如下所示: ```bash npm config set registry https://registry.npm.taobao.org ``` 此操作可显著提升下载速度并减少超时错误的发生概率[^4]。 #### 3. 选择合适的云服务商 对于希望将服务公开给更多用户的开发者来说,选用专业的云计算平台是非常重要的一步。常见的选项包括但不限于AWS、阿里云、腾讯云等。这些平台提供了丰富的功能和服务支持,帮助简化Node.js应用上线流程的同时也保障了系统的稳定性和安全性。 #### 4. 设置持续集成/持续交付(CI/CD)管道 通过自动化的方式处理版本控制、测试和发布环节不仅提高了效率还能降低人为失误的风险。GitHub Actions, Jenkins 或者 GitLab CI 是几个值得推荐的选择方案之一。 #### 5. 运行进程守护程序保持服务在线 即使是最可靠的软件也可能因为各种原因崩溃退出。因此建议采用 PM2 等专门设计用于监控nodejs项目的工具来自动重启失败的任务实例,并记录日志以便后续分析排查问题所在。 #### 6. 安全加固措施 - **HTTPS 加密传输**: 利用 Let's Encrypt 提供免费SSL证书实现数据加密保护。 - **API 密钥验证机制**: 对外部请求增加身份校验步骤防止未授权访问。 - **输入参数过滤**: 防范SQL注入攻击等问题发生。 --- ### 示例代码片段展示如何初始化express server 并监听指定端口 ```javascript const express = require('express'); const app = express(); app.get('/', (req, res) => { res.send('Hello World!'); }); // Set port number explicitly or rely on environment variable PORT. const PORT = process.env.PORT || 3000; app.listen(PORT, () => console.log(`Server running at http://localhost:${PORT}/`)); ``` 上述例子展示了创建一个基础webserver的过程,其中设置了默认端口号为3000除非另有定义来自操作系统级别的变量覆盖它[^1]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值