在使用jenkins進(jìn)行自動化部署服務(wù)的過程中,發(fā)現(xiàn)調(diào)用服務(wù)器的shell命令無法正常啟動tomcat,但是構(gòu)建日志顯示是成功執(zhí)行的,而手動在服務(wù)器卻是可以正常啟動tomcat。
原因:jenkins默認(rèn)在build結(jié)束后會kill掉所有的衍生進(jìn)程
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進(jìn)程
2.永久方案:啟動jenkins 的時候禁止jenkins殺死衍生進(jìn)程
● 使用java -jar啟動,-Dhudson.util.ProcessTree.disable=true -jar jenkins.war
● 使用Tomcat啟動,Linux系統(tǒng)修改catalina.sh,在環(huán)境變量的說明后,腳本開始前加上這句話
JAVA_OPTS="$JAVA_OPTS -Dhudson.util.ProcessTree.disable=true";
修改好Tomcat的配置文件后重新啟動Tomcat