`

Java定位CPU使用100%的方法

 
阅读更多

摘自:http://www.longtask.com/blog/?tag=jstack

流程:把线程dump出来,然后分析

1:Threaddump的方法:

  • kill -3 pid
  • jstack -l pid
  • jvisualvm中来thread dump

2:找到导致cpu高的线程
top -H -p pid
  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                            
 4691 root      19   0  448m 132m  13m S  0.0  7.5   0:00.01 java                                                               
 4692 root      19   0  448m 132m  13m S  0.0  7.5   0:00.39 java                                                               
 4698 root      15   0  448m 132m  13m S  0.0  7.5   0:14.14 java                                                               
 4699 root      15   0  448m 132m  13m S  0.0  7.5   0:00.43 java                                                               
 4700 root      15   0  448m 132m  13m S  0.0  7.5   0:00.63 java                                                               
 4701 root      18   0  448m 132m  13m S  0.0  7.5   0:00.00 java                                                               

 对应的线程id是十进制的,需要转换为十六进制的在threaddump文件中才可以看到

3:十进制转十六进制
-bash-3.2# python
>>> print hex(4739)
0×1283

4:找到对应的线程
vi threaddump.log
查找:/0×1283
找到对应的线程,把相关的方法找出来,可以精确到代码的行号,自己修改相关源码来fix bug。

分享到:
评论

相关推荐

    教你找出 运行java项目,使cpu 100%,如何排查出是哪个jar包的哪个线程导致的

    在Java开发过程中,有时会遇到项目运行时CPU占用率达到100%的问题,这可能是由于某个线程...通过深入理解这些工具和方法,你可以有效地预防和解决Java项目运行时CPU使用率过高的问题,从而确保应用程序的稳定性和效率。

    线上服务CPU100%问题快速定位实战

    本文将详细介绍一种实战演练的方法,用于定位线上服务中的高CPU使用率问题,并通过具体的案例来展示这一过程。 #### 二、问题背景 假设在一个服务器上部署了多个Tomcat实例,包括多个垂直切分的Java站点服务和...

    70-Java程序CPU占用1001

    在Java编程环境中,当遇到"Java程序CPU占用100%"的问题时,这通常意味着程序中存在性能瓶颈或者死循环,导致CPU资源被过度消耗。为了解决这个问题,我们需要进行一系列的诊断步骤来定位问题所在。以下是详细的排查...

    【原创】java程序cpu占用过高问题分析

    这些工具可以帮助开发者实时监控Java应用的CPU使用率、线程状态、内存分配等关键指标。 其次,对于线程分析,开发者应查看哪些线程消耗了大量CPU时间。Java的`jstack`命令可以输出线程堆栈信息,帮助我们定位到具体...

    Java问题定位技术(

    综上所述,Java问题定位技术是一项涉及JVM深入知识、多线程编程技巧、高并发实现方法、性能瓶颈分析能力以及内存泄漏处理的综合性技能。掌握这些知识点,能够有效解决Java应用程序在开发和运行过程中遇到的性能问题...

    java问题定位技术

    定位内存泄漏的方法包括使用Java内置的VisualVM工具,它可以显示JVM的内存分配情况,帮助开发者找到哪个类或者对象占用了大量内存。另外,还有像MAT (Memory Analyzer Tool)这样的专业分析工具,能提供更深入的分析...

    linux服务器找到占用cpu高的java代码的办法

    在Linux服务器环境中,Java应用程序可能由于各种原因导致CPU使用率过高,这可能会影响系统的整体性能。要找到占用CPU高的Java代码,我们可以采取一系列步骤来诊断和优化问题。以下是一种详细的方法: 1. **查看系统...

    Java问题定位技术.pdf

    为了方便开发者进行远程调试,文档还提供了有关远程调试工具的使用方法。 总结来说,这份文档是一份相当全面的Java问题定位与性能分析指南,覆盖了从基础的问题诊断方法到高级的性能调优策略,以及内存管理、并发...

    快速定位java程序cpu过高原因

    将定位cpu过高的命令做了一个整理,直接执行脚本定位问题

    CPU热点定位

    ### CPU热点定位技术详解 #### 一、引言 在软件开发过程中,性能问题是常见的挑战...综上所述,通过使用`jstack`和`top`工具结合的方式,我们可以有效地定位并解决Java应用中的CPU热点问题,从而提高应用的整体性能。

    Java进程cpu占用率高

    使用Java自带的JMX(Java Management Extensions)或者第三方工具(如JConsole、VisualVM)进行实时监控,可以获取CPU、内存、线程等关键指标,帮助定位问题。监控日志也是诊断问题的重要线索,确保JVM的诊断日志...

    cpu-use_CPU使用率_源码

    理解并掌握计算CPU使用率的方法,不仅有助于系统管理员监控系统健康状况,也是软件开发者优化程序性能的关键。例如,如果发现某个进程占用CPU过高,可以通过调整算法或优化代码来降低其对系统资源的需求。此外,对于...

    java进程占用CPU和内存太高问题排查相关测试文件.zip

    日常运维中,可以借助JMX(Java Management Extensions)或监控工具(如JProfiler, YourKit)实时监控Java进程的CPU和内存使用情况,提前预警并定位问题。 6. **性能日志**: 开启JVM的性能日志,如GC日志(-...

    基于java的Visualvm 基于JAVA的CPU硬件资源管理器源程序.zip

    它可以帮助开发者定位CPU消耗高的问题,通过查看方法调用栈,找出导致CPU负载过高的原因。源代码可能会包含对Java虚拟机(JVM)采样和解析数据的实现,以及如何将这些信息转化为用户友好的图形界面的代码。 3. **源...

    linux下查看java进程下线程占用cpu情况

    通过以上方法,你可以深入了解Linux下Java进程及线程对CPU的占用情况,从而进行问题定位和性能优化。在实际操作中,通常会结合多个工具和方法,以便从不同角度全面分析。记得,持续监控和分析是找出问题的关键。

    java问题定位

    本文主要介绍了Java问题定位的相关知识,包括常见的错误类型及其定位方法、高级问题定位技术以及针对特定问题的解决方案等。通过学习这些知识和技术,开发者可以更加高效地定位并解决Java程序中的问题,从而提高软件...

Global site tag (gtag.js) - Google Analytics