Java小案例-如果您的 Java 应用程序在不做任何事情时正在消耗 CPU,您如何确定它在做什么?

前言

我正在调用供应商的 Java API,在某些服务器上,JVM 在登录 API 后似乎进入了低优先级轮询循环(CPU 使用率为 100%)。其他服务器上的同一应用程序不会出现此行为。这发生在 WebSphere 和 Tomcat 上。环境设置起来很棘手,因此很难尝试在 Eclipse 中进行分析。

有没有办法分析(或其他检查方法)在 Tomcat 中运行的现有 Java 应用程序,以找出处于这种 spinwait 状态时正在执行的方法?当应用程序处于此状态时,它只执行一种方法(供应商的方法)。供应商无法复制该行为(当然)。

解决

JRockit 任务控制延迟分析器。

JRockit 附带的延迟分析器向您显示当 JVM 什么都不做时它正在"做什么"。在最新版本中,您可以看到以下延迟:

  • Java 等待/阻塞/睡眠/停放。
  • 文件输入/输出
  • 网络 I/O
  • 内存分配
  • GC 暂停
  • JVM 延迟,例如代码生成和类加载
  • 线程暂停

该工具会在延迟发生时为您提供堆栈跟踪。您可以通过多种不同方式查看延迟数据(聚合跟踪、作为直方图、在线程图中等)。该工具还允许您查看线程之间的转换,例如当一个线程通知另一个线程时。

开销可以忽略不计,并且与许多其他工具不同,它可以在生产环境中使用。这篇博文给你一个简单的介绍,程序可以再这里下载。

它可以免费用于开发!

联系方式

关于文章中提到的工具可以通过关注公众号《编程乐学》获取对应资料,同时,公众号还有更多有趣的项目以及关于学习编程的笔记资料大家可以看看,欢迎大家进行留言。

相关推荐
希忘auto几秒前
详解MySQL安装
java·mysql
娅娅梨3 分钟前
C++ 错题本--not found for architecture x86_64 问题
开发语言·c++
汤米粥9 分钟前
小皮PHP连接数据库提示could not find driver
开发语言·php
冰淇淋烤布蕾12 分钟前
EasyExcel使用
java·开发语言·excel
拾荒的小海螺18 分钟前
JAVA:探索 EasyExcel 的技术指南
java·开发语言
Jakarta EE35 分钟前
正确使用primefaces的process和update
java·primefaces·jakarta ee
马剑威(威哥爱编程)43 分钟前
哇喔!20种单例模式的实现与变异总结
java·开发语言·单例模式
白-胖-子1 小时前
【蓝桥等考C++真题】蓝桥杯等级考试C++组第13级L13真题原题(含答案)-统计数字
开发语言·c++·算法·蓝桥杯·等考·13级
好睡凯1 小时前
c++写一个死锁并且自己解锁
开发语言·c++·算法
java—大象1 小时前
基于java+springboot+layui的流浪动物交流信息平台设计实现
java·开发语言·spring boot·layui·课程设计