在使用jenkins進行自動化部署服務的過程中,發現調用服務器的shell命令無法正常啟動tomcat,但是構建日志顯示是成功執行的,而手動在服務器卻是可以正常啟動tomcat。
原因:jenkins默認在build結束后會kill掉所有的衍生進程
Jenkins提供了hudson.util.ProcessTree.disable和hudson.util.ProcessTreeKiller.disable兩個屬性來控制些特性,值為true將禁用此特性。hudson.util.ProcessTree.disable從Jenkins 1.260開始使用,而使用1.315之前的Hudson時只能使用hudson.util.ProcessTreeKiller.disable,為了版本兼容,在Jenkins 1.260后這兩個屬性都可能使用,建議使用1.260之的Jenkins用戶使用hudson.util.ProcessTree.disable屬性。
解決方案:
- 針對每個item:在execute shell輸入框中加入BUILD_ID=DONTKILLME,即可防止jenkins殺死啟動的tomcat進程
2.永久方案:啟動jenkins 的時候禁止jenkins殺死衍生進程
● 使用java -jar啟動,-Dhudson.util.ProcessTree.disable=true -jar jenkins.war
● 使用Tomcat啟動,Linux系統修改catalina.sh,在環境變量的說明后,腳本開始前加上這句話
JAVA_OPTS="$JAVA_OPTS -Dhudson.util.ProcessTree.disable=true";
修改好Tomcat的配置文件后重新啟動Tomcat
3. 在啟動jenkins 的時候禁止jenkins殺死衍生進程(此方法未測試,也是解決辦法之一)
修改/etc/sysconfig/jenkins配置,在JENKINS_JAVA_OPTIONS中加入-Dhudson.util.ProcessTree.disable=true。需要重啟jenkins生效
此方法配置一次后,所有的job都無需設置BUILD_ID,就能夠防止jenkins殺死啟動的java進程