VisualVM 是随JDK一同发布的jvm诊断工具,通过插件可以扩展很多功能,插件扩展也是其精华所在. 提供了一个可视界面,用于在Java应用程序在Java虚拟机上运行时查看有关Java应用程序的详细信息.此信息可用于对本地和远程应用程序进行故障排除以及对本地应用程序进行性能分析. 使用Java VisualVM,可以生成和分析堆转储,跟踪内存泄漏,执行和监视垃圾回收以及执行轻量级内存和CPU性能分析.该工具对于调整,堆大小,脱机分析和事后诊断也很有用. 使用方法 启动 cd <JDK_HOM…
JVM异常说明(超链接) 一文中已介绍了,JVM每个运行时区域--程序计数器 .Java虚拟机栈.本地方法栈.Java堆.方法区.直接内存发生OutOfMemoryError的不同原因和不同错误信息. Java堆,是线程共享内存,几乎所有的对象实例以及数组都应在堆上分配.如下堆的内存泄漏错误也是我们常常遇到的 java.lang.OutOfMemoryError: Java heap space 工具VisualVM的介绍 使用VisualVM排查堆内存泄漏 查看GC 老年代Old和年轻代Ede…
无论什么语言,在程序运行过程中,都需要对内存进行管理,要知道计算机/服务器的内存不是无限的.例如:C语言中需要对对象的内存负责,需要用delete/free来释放对象:那JAVA中,对象的内存管理是由JVM自动管理的. JVM是很有必要的了解认识的,因为在程序性能调优中极其重要的两个判断方向--运行时间和运行空间,都需要具备JVM的知识理解和工具使用,知其所以然才能无往不利 JVM虚机机的历史和类型 内存模型 程序计数器 程序计数器是一块较小的内存空间,它可以看作是当前线程所执行的字节码的行号指…
PMM(Percona Monitoring and Management) 是一个用于管理和监控数据库性能的开源平台. . 它能提供全面的基于时间和各类监控指标.计数器的分析. 性能测试中,是做数据库监控的较好工具. 官网 https://www.percona.com/doc/percona-monitoring-and-management/index.html 支持的数据库 mysql.mongodb.postgresql 原理分析 以mysql为例,整个工作的基本原理简单说: PMM-…
使用到 Grafana+Prometheus+Mysql_exportor 使用Prometheus和Grafana,可以快速的构建我们性能测试的绝大多数的监控模型:数据库监控.服务器监控.Jvm监控.Tomcat监控.Mq监控.Redis监控.Consul监控.Haproxy监控.Nginx监控 ....(明天见...) 构建正确和全链路的监控模型,是性能测试工作中必须的工作,也是性能测试的基础. 搭建性能测试Mysql监控模型 效果图 安装Mysqld_exporter 在需要监控的数据库服…
死锁原因 Java发生死锁的根本原因是:在申请锁时发生了交叉闭环申请.即线程在获得了锁A并且没有释放的情况下去申请锁B,这时,另一个线程已经获得了锁B,在释放锁B之前又要先获得锁A,因此闭环发生,陷入死锁循环. 监控死锁 VisualVM监控工具有明显线程死锁提醒,也可监控到发生死锁的线程.类.代码行数.数据类型. 分析死锁 VisualVM生成threaddump,查找死锁代码块内存地址 VisualVM生成heapdump, 使用OQL查看被死锁对象的值和引用 select heap.fin…
安装配置Grafana参考 https://testerhome.com/articles/23629 使用配置 下载jmx_exporter https://github.com/prometheus/jmx_exporter 创建jmx_exporter配置文件 vim simple-config.yml lowercaseOutputLabelNames: true lowercaseOutputName: true whitelistObjectNames: ["java.lang:ty…
技术交流群:233513714 本文是<JVM 性能调优实战之:一次系统性能瓶颈的寻找过程> 的后续篇,该篇介绍了如何使用 JDK 自身提供的工具进行 JVM 调优将 TPS 由 2.5 提升到 20 (提升了 7 倍),并准确定位系统瓶颈:我们应用里静态对象不是太多.有大量的业务线程在频繁创建一些生命周期很长的临时对象,代码里有问题.那么问题来了,如何在海量业务代码里边准确定位这些性能代码?本文将介绍如何使用阿里开源工具 TProfiler 来定位这些性能代码,成功解决掉了 GC 过于频繁的…
16年的时候花了一些时间整理了一些关于jvm的介绍文章,到现在回顾起来还是一些还没有补充全面,其中就包括如何利用工具来监控调优前后的性能变化.工具做为图形化界面来展示更能直观的发现问题,另一方面一些耗费性能的分析(dump文件分析)一般也不会在生产直接分析,往往dump下来的文件达1G左右,人工分析效率较低,因此利用工具来分析jvm相关问题,长长可以到达事半功倍的效果来. jvm监控分析工具一般分为两类,一种是jdk自带的工具,一种是第三方的分析工具.jdk自带工具一般在jdk bin目录下面,…
性能分析神器VisualVM 9602 VisualVM 是一款免费的,集成了多个 JDK 命令行工具的可视化工具,它能为您提供强大的分析能力,对 Java 应用程序做性能分析和调优.这些功能包括生成和分析海量数据.跟踪内存泄漏.监控垃圾回收器.执行内存和 CPU 分析,同时它还支持在 MBeans 上进行浏览和操作.本文主要介绍如何使用 VisualVM 进行性能分析及调优. 目录: 准备工作 内存分析篇 内存堆Heap 永久保留区域PermGen CPU分析篇 线程分析篇 参考文献 准备工作…