一次因信号量引发的tomcat异常退出解决

2019-10-18 20:08:27于海丽

接下来的事情就简单了。把程序上传服务器,通过WEB控制台登录服务器,将执行结果重定向到文本文件中,然后静待控制台超时。结果如下。

结果不用再分析了,WEB控制台会在退出时发出SIGHUP,相当于kill -1。而tomcat在收到SIGHUP会怎么操作呢?小伙伴们可以试试看kill -1 pid,再看看日志,就明白了。

解决方案其实也简单。SIGHUP是HANG UP的意思,可以用nohup xx.sh &来彻底屏蔽SIGHUP和SIGINT。另外,经过测试发现,通过单击SecureCRT的tab页右侧的×也可以触发信号量,而直接logout或者点菜单上的红叉则并不会触发。

感兴趣的小伙伴可以把这个程序扩展一下,测测看。说不定你的异常退出问题也能迎刃而解呢。

此问题的解决离不开上海中通的刘建刚同学,特此致谢。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对易采站长站的支持。