本文是Jenkins应用系统文章的一部分,大部分来自工作和学习中的实践,部分内容来自官方文档和网友的文章,引用的文章会在“参考资料”部分附上原始链接,如无意中侵犯您的权利,请联系QQ:46106962,如需要进一步的交流请加入QQ群:(Jenkins部落:469536515,Jenkins部落-2:141762278)。转载和使用请注明出处。
在部落内部时不时的会有同学问一为什么在execute shell中不能启动tomcat、为什么在windows batch中不能启动tomcat等问题,其实大部分情况下不是不能启动,而是启动后随着job结束进程被杀死,造成不能启动的假象,这一点从tomcat的日志中可以看来,虽然也给出了解决方法,但没有回答本质问题,利用周末和晚上的时间对这个问题进行探究,并总结下来供大家参考。
Jenkins为了有效的杀死job运行时创建的子进程,提供了一些原生代码找到并杀死它们,这样做非常合理,当一个job结束时势必要杀死运行期间启动的进程,否则系统里会留下很多僵尸进程。尽管Jenkins声称这个功能在各种环境下做了测试,但为了应付在特殊环境下出现的特殊情况,Jenkins提供了禁用此特性的方法。
Jenkins的做法虽然非常合理,但也造成了一些问题,如我们希望在execute shell或windows batch中启动的web应用在job结束后继续运行,可以通过两种方法达到这个目录,下面分介绍。
方法一:通过Jenkins提供的启动参数禁用杀死子进程的特性
Jenkins提供了hudson.util.ProcessTree.disable和hudson.util.ProcessTreeKiller.disable两个属性来控制些特性,值为true将禁用此特性。hudson.util.ProcessTree.disable从Jenkins 1.260开始使用,而使用1.315之