JProfiler学习笔记一

简介:

                                    JProfiler学习笔记一

一、他是一个商业工具,学习他能解决JAVA性能定位问题;

wKioL1mWyFLiddZHAAEUu-qJXrc463.jpg-wh_50

1、点击第一个,再跳转的页面选择需要监控的机器,如果没有配置需要配置成功

2、选择监控内容,点击确定

wKioL1mWyVfQMcpJAAIYrool4s0664.jpg-wh_50

二、简单使用

1、点击Memory

wKiom1mWyuPSb0_MAAIIqMpLOsU702.jpg-wh_50

wKioL1mWzNezwmX8AAGDb_Gfzn4944.jpg-wh_50

标记后就成绿色:

标记的好处:可以区分那些是新增的,那些是新增后不回收的对象

wKiom1mWzNrBr0H1AACPsW-URUQ428.jpg-wh_50


wKioL1mWzW-BK2LqAACSKIwztHc029.jpg-wh_50

  • 所有对象 
    显示类或在状况统计和尺码信息堆上所有对象的包。你可以标记当前值并显示差异值。

  • 记录对象 Record objects 
    显示类或所有已记录对象的包。你可以标记出当前值并且显示差异值。

  • 分配访问树 Allocation call tree 
    显示一棵请求树或者方法、类、包或对已选择类有带注释的分配信息的J2EE组件。

  • 分配热点 Allocation hot spots 
    显示一个列表,包括方法、类、包或分配已选类的J2EE组件。你可以标注当前值并且显示差异值。对于每个热点都可以显示它的跟踪记录树。

wKiom1mWzdKwqwZ8AAElSXcnKDE317.jpg-wh_50

在JProfiler的堆遍历器(Heap walker)中,你可以对堆的状况进行快照并且可以通过选择步骤下寻找感兴趣的对象。堆遍历器有五个视图:

  • 类 Classes 
    显示所有类和它们的实例。

  • 分配 Allocations 
    为所有记录对象显示分配树和分配热点。

  • 索引 References 
    为单个对象和“显示到垃圾回收根目录的路径”提供索引图的显示功能。还能提供合并输入视图和输出视图的功能。

  • 数据 Data 
    为单个对象显示实例和类数据。

  • 时间 Time 
    显示一个对已记录对象的解决时间的柱状图。

  • wKiom1mW1u7j8XPYAAEaHnzAUuk398.jpg-wh_50

  • CPU 剖析 CPU profiler

  • JProfiler 提供不同的方法来记录访问树以优化性能和细节。线程或者线程组以及线程状况可以被所有的视图选择。所有的视图都可以聚集到方法、类、包或J2EE组件等不同层上。CPU视图部分包括:

  • 访问树 Call tree 
    显示一个积累的自顶向下的树,树中包含所有在JVM中已记录的访问队列。JDBC,JMS和JNDI服务请求都被注释在请求树中。请求树可以根据Servlet和JSP对URL的不同需要进行拆分。

  • 热点 Hot spots 
    显示消耗时间最多的方法的列表。对每个热点都能够显示回溯树。该热点可以按照方法请求,JDBC,JMS和JNDI服务请求以及按照URL请求来进行计算。

  • 访问图 Call graph 
    显示一个从已选方法、类、包或J2EE组件开始的访问队列的图。


wKioL1mW1qfzjZmPAAHZvC5wiyA404.jpg-wh_50

wKiom1mW2WWyLlcnAAKD_uowiY4314.jpg-wh_50


线程剖析 Thread profiler

对线程剖析,JProfiler提供以下视图:

  • 线程历史 Thread history 
    显示一个与线程活动和线程状态在一起的活动时间表。

  • 线程监控 Thread monitor 
    显示一个列表,包括所有的活动线程以及它们目前的活动状况。

  • 死锁探测图表 Deadlock Detection 
    显示一个包含了所有在JVM里的死锁图表。

  • 目前使用的监测器 Current monitor useage 
    显示目前使用的监测器并且包括它们的关联线程。

  • 历史检测记录 History usage history 
    显示重大的等待事件和阻塞事件的历史记录。

  • 监测使用状态 Monitor usage statistics 
    显示分组监测,线程和监测类的统计监测数据。


wKioL1mW1yXQ8eDmAAF3Gw1GjRA743.jpg-wh_50

当前锁的情况

wKiom1mW14ziNcAKAADokGsvyaM981.jpg-wh_50

代码中使用SQL语句情况

wKioL1mW18rjhtGpAAKWBxosXMk267.jpg-wh_50

功能挺强大,希望给大家一个展现。










本文转自 知止内明 51CTO博客,原文链接:http://blog.51cto.com/357712148/1957465,如需转载请自行联系原作者
目录
相关文章
|
供应链 数据库 开发者
深入了解数据库锁:类型、应用和最佳实践
深入了解数据库锁:类型、应用和最佳实践
|
Java Android开发
jvisualvm分析jvm内存溢出
jvisualvm分析jvm内存溢出
1685 0
jvisualvm分析jvm内存溢出
|
存储 机器学习/深度学习 算法
第十五届蓝桥杯pb组国赛E题[马与象] (15分)BFS算法 详解
第十五届蓝桥杯pb组国赛E题[马与象] (15分)BFS算法 详解
371 3
|
5月前
|
NoSQL Redis 数据安全/隐私保护
挂载配置文件以Docker启动Redis服务
以上步骤提供了一个高效且实用的方式来使用Docker启动并运行带有自定义配置的Redis服务。这些操作可以适用于开发、测试和生产环境,是一种灵活且可扩展的部署方案。通过挂载配置文件和数据卷,您可以轻松地管理和迁移您的Redis实例。
644 9
|
监控 Java 开发者
Java一分钟之-Java性能分析与调优:JProfiler, VisualVM等工具
【5月更文挑战第21天】本文介绍了Java性能优化的两个利器——JProfiler和VisualVM。JProfiler通过CPU Profiler、内存分析器和线程视图帮助解决过度CPU使用、内存泄漏和线程阻塞问题;VisualVM则聚焦于GC行为调整和类加载优化,以减少内存压力和提高应用性能。使用这些工具进行定期性能检查,是提升Java应用效率的关键。
543 0
|
人工智能 自然语言处理
人工智能在创意写作中的应用与挑战
本文探讨了人工智能(AI)在创意写作领域的应用及其面临的挑战。通过分析AI技术如何辅助作家创作,提高写作效率和质量,同时指出AI在理解人类情感、文化背景及创造性思维方面的局限性。文章旨在提供一个关于AI与人类协作在文学创作中可能的未来发展的视角。
|
存储 数据采集 JSON
彻底搞懂监控系统,使用Prometheus +Grafana搭建完整的应用监控系统
监控是运维系统的基础,我们衡量一个公司/部门的运维水平,看他们的监控系统就可以了。一个完善的监控系统可以提高应用的可用性和可靠性,在提供更优质服务的前提下,降低运维的投入和工作量,为用户带来更多的商业利益和客户体验。下面就带大家彻底搞懂监控系统,使用Prometheus +Grafana搭建完整的应用监控系统。
16520 1
彻底搞懂监控系统,使用Prometheus +Grafana搭建完整的应用监控系统
|
存储 TensorFlow API
深度学习系统设计(二)(5)
深度学习系统设计(二)
312 1
|
分布式计算 网络协议 大数据
基于C++的分布式计算框架设计与实现
基于C++的分布式计算框架设计与实现
1069 2