文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

【JVM 监控工具】性能诊断--JProfiler的使用

2023-09-03 09:21

关注

文章目录

性能诊断是软件工程师在日常工作中需要经常面对和解决的问题,在用户体验至上的今天,解决好应用的性能问题能带来非常大的收益。Java 作为最流行的编程语言之一,其应用性能诊断一直受到业界广泛关注。可能造成 Java 应用出现性能问题的因素非常多,例如线程控制、磁盘读写、数据库访问、网络I/O、垃圾收集等。想要了定位这些问题,一款优秀的性能诊断工具必不可少。本文将介绍 Java 性能诊断过程中的常用工具,并重点介绍其中的优秀代表 JProfiler 的基本原理和最佳实践(本文所做的调研基于jprofiler10.1.4)。

在 Java 的世界里,有许多诊断工具可供选择,既包括像 jmap、jstat 这样的简单命令行工具,又包括 JVisualvm、JProfiler 等图形化综合诊断工具,同时还有 SkyWalking、ARMS 这样的针对分布式应用的性能监控系统。下面分别对其进行介绍。

JDK 内置了许多命令行工具,它们可用来获取目标 JVM 不同方面、不同层次的信息。

使用上述命令行工具或组合能帮您获取目标 Java 应用性能相关的基础信息,但它们存在下列局限:

  1. 无法获取方法级别的分析数据,如方法间的调用关系、各方法的调用次数和调用时间等(这对定位应用性能瓶颈至关重要)。
  2. 要求用户登录到目标 Java 应用所在的宿主机上,使用起来不是很方便。
  3. 分析数据通过终端输出,结果展示不够直观。

下面介绍几款图形化的综合性能诊断工具。

JVisualvm

JVisualvm 是 JDK 内置的可视化性能诊断工具,它通过 JMX、jstatd、Attach API 等方式获取目标 JVM 的分析数据,包括 CPU 使用率、内存使用量、线程堆栈信息等。此外,它还能直观地展示 Java 堆中各对象的数量和大小、各 Java 方法的调用次数和执行时间等。

更多可参考我之前写的文章:【JVM 监控工具】JVisualVM的使用

JProfiler

JProfiler 是由 ej-technologies 公司开发的一款 Java 应用性能诊断工具。它聚焦于四个重要主题上。

JConsole

使用JConsole监控进程、线程、内存、cpu、类情况

如果只需要诊断单机 Java 应用的性能瓶颈,上面介绍的诊断工具就已经够用了。但随着现代系统架构逐渐从单体转变为分布式、微服务,单纯使用上述工具往往无法满足需求,这时就需要借助 Jaeger、ARMS、SkyWalking 这些分布式追踪系统提供的全链路追踪功能。分布式追踪系统种类繁多,但实现原理都大同小异,它们通过代码埋点的方式记录 tracing 信息,通过 SDK 或 agent 将记录的数据传输至中央处理系统,最后提供 query 接口对结果进行展示和分析。

JProfiler是什么

​ JProfiler直觉式的GUI让你可以找到性能瓶颈、抓出内存漏失(memory leaks)、并解决执行绪的问题。它让你得以对heap walker作资源回收器的root analysis,可以轻易找出内存漏失;heap快照(snapshot)模式让未被参照(reference)的对象、稍微被参照的对象、或在终结(finalization)队列的对象都会被移除;整合精灵以便剖析浏览器的Java外挂功能。

功能

安装

IEAR下载插件JPrifiler
在这里插入图片描述

安装完插件记得重启IDEA.出现下图标准表示安装成功

在这里插入图片描述

congqi官网下载JProfiler客户端并安装。 官网下载地址:https://www.ej-technologies.com/download/jprofiler/files

使用

生成快照

public class vmtest {    public static int i=1;    public static void main(String[] args) {        final long max= Runtime.getRuntime().maxMemory();//jvm的视图使用的最大内存        final long total = Runtime.getRuntime().totalMemory();//jvm初始化内存        final int cpu = Runtime.getRuntime().availableProcessors();//cpu核数            System.out.println("虚拟机获得最大内存"+(max/1024/1024)+"m");        System.out.println("初始最大内存"+(total/1024/1024)+"m");        System.out.println("本机核数:"+cpu);        String s = new String();        while(true){           final byte[] bytes = new byte[1024 * 1024*1024];       }    }}

配置VM

在这里插入图片描述

运行程序

我们预期效果达到,堆内存超出。
在这里插入图片描述

打开项目目录找到生成的快照,并用JProfiler工具打开

在这里插入图片描述

进入JProfiler

查看堆中的实例

在这里插入图片描述

查看在哪里报错

在这里插入图片描述

本地运行

在这里插入图片描述

进入JProfiler

可以查程序运行时的实时数据

在这里插入图片描述

生成快照

进入JProfiler

可以查程序运行时的实时数据

在这里插入图片描述

生成快照

在这里插入图片描述

来源地址:https://blog.csdn.net/u011397981/article/details/131210536

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯