首页
学习
活动
专区
圈层
工具
发布

Tomcat进程意外退出,元凶居然是他...

作者 | 宏江 出品 | 并发编程网(ifeve.com) 节前某个部门的测试环境反馈tomcat会意外退出,我们到实际环境排查后发现不是jvm crash,日志里有进程销毁的记录,从pause到destory...那就只剩下Signal的情况了;经过一番排查后,发现每次tomcat意外退出的时间与ssh会话结束的时间正好吻合。...这种情况下,如果用户直接关闭ssh终端的窗口(用鼠标或快捷键),则java进程也会退出。而如果先ctrl-c终止test.sh进程,然后再关闭ssh终端的话,则java进程不会退出。...ssh终端窗口会导致java进程退出?...因为java后台进程从父进程catalina.sh(又是从其父进程test.sh)继承的pgid,所以java进程仍属于test.sh进程组里的成员,收到SIGHUP后退出。

4.5K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Java进程异常退出

    参考链接: Java中的异常 今天,内网测试服务器A总是运行一段时间就服务器进程自行退出了,给出了“Java Result :137”这样的错误码。上网查了一下这个137,感觉没有啥有价值的东西。...拿起手机,随意搜了一下“JAVA进程无端退出”,看到了一篇博客提出一个运维神指令dmesg(ps:有时候这个真是救命的神指令)可以查到一个进程的异常信息,在故障诊断方面非常有用。...,这下舒了一口气,JVM进程退出的原因算是知道了,被系统杀掉了,难怪看不到log。       ...,就会触发OOM(out of memory),从而导致进程退出,后来经过和运维同学确认这个机器配置,符合我的猜想,Docker且内存限制8G(低于设置的Xmx12G)。...总结:  1、在无异常log情况,应用退出,可以先考虑系统中断,dmesg查询相关信息  2、docker环境会影响应用,使用需要慎重,尤其是开发者和运维人员分离的情况下,开发者应该尽量了解到运维对系统的设置

    4.7K30

    openGauss备机追数Catchup过程中主库写入阻塞问题

    最近在测试openGauss主从复制时发现一个问题:当备机落后主机很多时(比如停了一段时间后再启动),启动后会自动的追数,追数的过程状态是catchup,而在catchup的过程中,主库上的写入会全部阻塞...主从搭建会自动创建物理复制槽,所以备库需要的xlog主库不会自动清理,那么我们就可以先把两个备库都停掉(我这里的环境是一主两备),然后在主库插入大量数据,产生大量xlog的堆积,然后过一段时间再挨个开启备库,查看追数过程中...standby 观察状态,虽然sync_percent没有完全同步完,状态是catchup,(有时候也有可能是normal,可能和主备启动时间间隔有关),因为此时已经有一个正常同步的备库,这时第二个备库在追数过程中不会影响主库...14:07:30 13310 14:07:31 15119 14:07:32 15165 14:07:33 14045 为了找到catchup过程中阻塞主机的根本原因

    1K20

    Java - 探究Java优雅退出的两种机制

    Java优雅停机_ ShutdownHook 机制 Java的优雅停机通常通过注册JDK的ShutdownHook来实现,当系统接收到退出指令时,首先标记系统处于退出状态,不再接收新的消息,然后将积压的消息处理完...Java的ShutdownHook(关闭钩子)是一种机制,允许开发人员在Java虚拟机(JVM)即将关闭时执行一些特定的代码。...Java优雅停机_ 信号量机制 除了注册ShutdownHook,还可以通过监听信号量并注册SignalHandler 的方式实现优雅退出。...具体来说,SignalHandler在Java中是一个接口,它由sun.misc包下的Java类提供。...注意事项 使用Java的ShutdownHook(注册在JVM层面的钩子)进行应用的优雅退出时,有几个重要的注意事项: ShutdownHook的执行不确定性:ShutdownHook并非在所有情况下都会被

    1.3K00
    领券