Liunx启动tomcat失败,查询后发现存在defunct进程

版权声明:转载请注明原创地址,否则依法追究法律责任 https://blog.csdn.net/weixin_38964895/article/details/83053759

前言

    > 在部署项目时,进入到tomcat路径下,启动tomcat时发现启动失败,查看日志信息发现是:之前的tomcat在shutdown时失败,导致新的进程也无法启动,于是就使用ps指令找到对应的PID,想通过kill -9的方式杀掉该进程,然后再启动就可以了,此时就发现问题出现

   kill -9 PID 的方式是无法杀死僵尸进程的

  进一步搜索资料后发现解决方案有两种

  1.ps -ef|grep defunt more

   查找出对应的dufunct进程的PID对应的父ID,杀死本身的PID是无法杀死的,只能通过杀死父ID来解决。但是如果该父ID为1,那就要注意了,该进程是负责整个Linux的基本初始化工作,kill之后整个服务器基本就不行了,此时就要尝试第二种解决方案

  2.重启服务器

   正常来说,一般的进程在时间内不执行,符合GC标准之后是会被回收的,举个例子,假如System.gc()调用了本地库glic6.0.2.so那么在当前系统上没有这个版本的库或没有这个版本的库的链结,那么gc()方法肯定不能正确工作。当然sun在发布的时候可能会把这个本地库打包在JDK发行包中,但glic6.0.2.so中又调用了其它库,如subglic6.0.21.so,即使系统中存在完全相同的glic6.0.2.so,它调用的库又不一定完全匹配,才使得需要调用本地库的JVM底层功可能会产生异常,导致清除/退出进程等工作就可能无法完成,产生了java defunct,甚至有些时候还会出现tomcat产生多进程的情况
 

  目前搜集到能解决的解决方案就是上述两种,有别的解决方案欢迎探讨

猜你喜欢

转载自blog.csdn.net/weixin_38964895/article/details/83053759
今日推荐