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

createh53个月前 (02-01)技术教程25

最近同事开发的一个项目部署上线后用过几天就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启动线程时一定要关闭。

相关文章

我的世界:java vs 基岩的11个不同之处!这是,天堂传送门?

《我的世界》基岩版 vs Java版向来不是完全统一的两个版本,最为经典的差异想必也就是为人所熟知的“船”的合成配方了。然而我们今天就来聊一些更为细节的不同之处!1、基岩版的船无法承载掉落物,JAVA...

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

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

如何优雅地关闭线程池?(关闭线程的方法)

在 Java的线程池管理中,shutdown()和shutdownNow()是用于关闭线程池的两种方法,尽管都是为了关闭线程池,但它们存在显著差异。这篇文章,我们将详细阐述它们的工作原理。shutdo...

【Linux】Linux服务器高效关闭JAR包服务的绝妙技巧

本文介绍以下几种方法有效地在Linux服务器上关闭正在运行的JAR包服务。在Linux服务器上关闭JAR包服务,可以通过以下几种方法实现:一、使用ps和kill命令查找JAR包进程ID:ps aux...

不要让你的Java对象"逃逸"了

经常会有面试官会问一个问题:Java中的对象都是在"堆"中创建吗?然后跟求职者大谈特谈"逃逸分析",说通过"逃逸分析",JVM会将实例对象分配在"栈"上。其实这种说法是并不是很严谨,最起码目前在Hot...

连接池:别让连接池帮了倒忙(连接池的作用及原理)

今天,我再与你说说另一种很重要的池化技术,即连接池。我先和你说说连接池的结构。连接池一般对外提供获得连接、归还连接的接口给客户端使用,并暴露最小空闲连接数、最大连接数等可配置参数,在内部则实现连接建立...