记一次TOMCAT开启一段时间自动关闭

createh54个月前 (02-01)技术教程33

最近同事开发的一个项目部署上线后用过几天就TOMCAT自动关闭,并且该项目没有开通对外访问。通过阿里云监控台查看,从升级后系统内存占用上升趋势,CPU等信息没有太大变化。

打印服务器日志后发现全是线程日志。并且过一段时间后会发现停留大日志里的线程数逐步增加,通过命令定时查看服务器观察应用线程数,按时间在递增。综合以上分析初步定位是开启线程数多没有关闭导致程序占用系统内存多从而TOMCAT关闭。



top --查看JAVA线程ID

top -Hp pid -d 1 -n 1 --查看当前的较高的线程

jstack 28174 > dump.txt --打印日志


ps huH p pid | wc -l -- 发现每隔1分钟线程数一直在增加。

按日志查到程序使用线程情况,并且全文搜索程序使用线程的方法,再结合开发的同事提供的信息,定位问题。

优化后:

优化上线后再观察线程数正常。

分析:使用ScheduledExecutorService启动线程时一定要关闭。

相关文章

还不理解 Error 和 Exception 吗,看这篇就够了

在 Java 中的基本理念是 结构不佳的代码不能运行,发现错误的理想时期是在编译期间,因为你不用运行程序,只是凭借着对 Java 基本理念的理解就能发现问题。但是编译期并不能找出所有的问题,有一些 N...

使用 kill 命令杀死 java进程,你用对了吗?

原文地址:https://dwz.cn/E88v8sLN作者: 占小狼在本地调试agent相关功能,需要经常性的杀掉Java进程,验证一些极端情况。每次都是本能执行如下步骤jpskill -9rebo...

经验分享|程序员成功转行IC,我终于不用再吃“青春饭”

近期后台收到了一位同学的私信,转行IC后他的薪资涨了很多,这位同学之前是程序员,经过不断努力成功转行到IC后端。我是西安一所普通的一本毕业,学的是自动化专业,大学跟大多数人一样过得浑浑噩噩,对自己的职...

实战!如何在退出登录时借助外力使JWT令牌失效?

大家好,我是不才陈某~今天这篇文章介绍一下如何在修改密码、修改权限、注销等场景下使JWT失效。文章的目录如下:解决方案JWT最大的一个优势在于它是无状态的,自身包含了认证鉴权所需要的所有信息,服务器端...

Linux系统怎么后台运行jar项目和关闭jar项目的方法

Linux后台运行和关闭jar项目该怎么操作呢?下面我们来讲一下!直接用下面这个命令java -jar xxx.jar当退出或关闭shell时,程序就会停止掉。以下方法可让jar运行后一直在后台运行。...

如何处理资源关闭异常?(关闭资源管理器的错误方法)

在Java中,处理资源关闭异常通常涉及以下几个步骤:使用try-with-resources语句来自动关闭资源。在try-with-resources块后面添加一个catch块来捕获并处理资源使用过程...