先上能正常启动的样子,重要的地方标记了注意。
首先,jenkins 的build脚本,是这样子的。
#!/bin/bash
OLD_ID=${BUILD_ID}
# 注意:1 这里要改
BUILD_ID=dontKillMe
cd ${WORKSPACE}
echo pwd: `pwd`
/opt/node-v8.11.2-linux-x64/bin/pm2 list
/opt/node-v8.11.2-linux-x64/bin/pm2 stop myapp
npm -v
echo start install...
npm -d install
echo start server...
date > log.txt
/opt/node-v8.11.2-linux-x64/bin/pm2 start app.js --name myapp --output log.txt --error log.txt &
echo start end.
# 注意:2 这里要改回去
BUILD_ID=${OLD_ID}
然后,需要修改jenkins自身的启动设置项目:
# vi /etc/rc.d/init.d/jenkins
JAVA_CMD="$JENKINS_JAVA_CMD $JENKINS_JAVA_OPTIONS -DJENKINS_HOME=$JENKINS_HOME -jar $JENKINS_WAR"
# 注意:3 改成
JAVA_CMD="$JENKINS_JAVA_CMD $JENKINS_JAVA_OPTIONS -DJENKINS_HOME=$JENKINS_HOME -Dhudson.util.ProcessTree.disable=true -jar $JENKINS_WAR"
# 就是添加了 -Dhudson.util.ProcessTree.disable=true
然后重新启动jenkins,执行jenkins build任务,看到node服务已经启动了。
一开始没有做第二步的设置jenkins启动参数,好不容易看到启动成功了,也连不上服务器,耽误了很多时间。设置pm2 的–watch参数后,发现pm2一直在重新启动,才想起来可能是jenkins关闭了程序。然后在网上看到有人提到jenkins真的会自动关闭它启动的进程。
官方的解释:
https://wiki.jenkins-ci.org/display/JENKINS/ProcessTreeKiller
https://issues.jenkins-ci.org/browse/JENKINS-28182