java几乎耗尽了所有的CPU

简介:
现象如下:
刚启动后,java几乎耗尽了所有的CPU,压力大嘛。
几分钟后,CPU 100% idle, tomcat也不接受任何请求了,感觉就是tomcat死了。
ps -efL | grep java | wc -l 可以发现tomcat的线程池满了,每个线程都在,就是不工作了。

难道tomcat有bug? 在高压力的情况下工作不正常?
google后发现,有这种问题还不在少数,具体原因也不尽相同,但根本的原因就一个“线程发生了死锁”。 这就好理解了,所有的线程都在等待某种资源,所以也就idle了。

如何知道每个线程都在等待什么呢?
1、 ps -ef | grep java
      得到java的pid
2、kill -QUIT "得到的pid"
      这个命令给java发送了一个信号,tomcat会把每个线程的情况写在tomcat的日志文件catalina.out中
相关文章
|
11月前
|
存储 缓存 前端开发
JavaEE初阶——初识EE(Java诞生背景,CPU详解)
带你从零入门JAVAEE初阶,Java的发展历程认识什么是cpu,cpu的工作原理,cpu是如何进行计算的,cpu的架构,指令集,cpu的核心,如何提升cpu的算力,cpu的指令,,cup的缓存,cpu的流水线
|
11月前
|
Java 对象存储 开发者
如何找出Java进程占用CPU高的元凶
本文记录了一次Java进程CPU占用率过高的问题和排查思路。
|
存储 缓存 算法
面试官:单核 CPU 支持 Java 多线程吗?为什么?被问懵了!
本文介绍了多线程环境下的几个关键概念,包括时间片、超线程、上下文切换及其影响因素,以及线程调度的两种方式——抢占式调度和协同式调度。文章还讨论了减少上下文切换次数以提高多线程程序效率的方法,如无锁并发编程、使用CAS算法等,并提出了合理的线程数量配置策略,以平衡CPU利用率和线程切换开销。
面试官:单核 CPU 支持 Java 多线程吗?为什么?被问懵了!
|
Java
Java面试题之cpu占用率100%,进行定位和解决
这篇文章介绍了如何定位和解决Java服务中CPU占用率过高的问题,包括使用top命令找到高CPU占用的进程和线程,以及使用jstack工具获取堆栈信息来确定问题代码位置的步骤。
895 0
Java面试题之cpu占用率100%,进行定位和解决
|
小程序 JavaScript Java
【Java】服务CPU占用率100%,教你用jstack排查定位
本文详细讲解如何使用jstack排查定位CPU高占用问题。首先介绍jstack的基本概念:它是诊断Java应用程序线程问题的工具,能生成线程堆栈快照,帮助找出程序中的瓶颈。接着,文章通过具体步骤演示如何使用`top`命令找到高CPU占用的Java进程及线程,再结合`jstack`命令获取堆栈信息并进行分析,最终定位问题代码。
1523 2
【Java】服务CPU占用率100%,教你用jstack排查定位
|
存储 Java API
【Azure Developer】通过Azure提供的Azue Java JDK 查询虚拟机的CPU使用率和内存使用率
【Azure Developer】通过Azure提供的Azue Java JDK 查询虚拟机的CPU使用率和内存使用率
161 0
|
Java
手把手教你java CPU飙升300%如何优化
手把手教你java CPU飙升300%如何优化
245 0
|
Java
Jstack 查看线程状态及定位占用 cpu 较高的 java 线程
Jstack 查看线程状态及定位占用 cpu 较高的 java 线程
1310 2
|
监控 算法 Java
|
监控 算法 Java
压测分析Java内存和CPU暂用
7月更文挑战第7天
193 5