好记性不如烂笔头,戊戌年的最后一个工作日,把自己平时在开发过程中使用的一些java性能优化工具做一个简单的小结,

主要包括 jvisualvm、jfr、gdb和查看内存对象信息的几个linux命令。

注:当前系统属性 Mac OS X 10.13.6,jdk版本 1.8.0_151

1:jvisualvm(当前java自带的工具)

可以看到jvisualvm不仅支持本地应用程序的追踪还支持远程。

然后打开对应的本地项目:

这里面确实有很多项目的信息,CPU、堆栈信息等。

我目前使用它就是用它的抽样器,查看当前项目里的对象数及对象占用的内存大小。

这样对项目中某个对象个数过多或者对象过大,就可以方便的查看到,然后去优化它。

2:JFR

jfr的优点:

VisualVM功能强大,支持图形化界面操作,可以很快定位代码问题。但是它对应用性能的影响也非常大,所以不适合在生产环境下使用。

还有这些软件(比如GDB(下面介绍))要attach到jvm进程上,生产环境一般网络隔离,很难做到。

使用jfr不需要在现有应用上额外添加任何参数、重启进程等,直接在命令行执行即可,实时生效,100%无入侵,且稳定可靠,不影响线上应用运行。

jfr的使用:

2.1:本地使用:

1:需要在项目jvm加上配置 vm options:-XX:+UnlockCommercialFeatures -XX:+FlightRecorder

2:打开jmc

3:打开对应的进程ID,就可以追踪本项目的堆栈、CPU等信息

2.2:在服务器上使用:

1:由于JFR需要JDK的商业证书,这一步需要解锁jdk的商业特性:

  jcmd <PID> VM.unlock_commercial_features

2:启动jrf,开始输出jfr文件

  jcmd <PID> JFR.start name=test duration=60s filename=/tmp/output.jfr

3:拿到jfr文件后,在本地打开jmc图形化工具后,选择文件直接打开,然后就可以看到服务器上duration时间间隔的项目信息。

当然无论是本地运行还是在服务器上运行,Java飞行记录器都支持创建一个模板。

在高级模式中,你可以自定义自己想要的信息。

创建好模板后,无论是在本地还是复制到远程服务器上,

jcmd <PID> JFR.start name=test duration=60s settings=template.jfc filename=/tmp/output.jfr

settings=template.jfc就可以指定使用templayte.jfc这个模板的配置去收集项目信息。

3:GDB(参考文章:https://www.atlassian.com/blog/archives/so-you-want-your-jvms-heap

首先机器上需要安装gdb,gdb的安装就不赘述了,

sudo apt-get install gdb

sudo yum install gdb

brew install gdb

1:使用gdb生成java heap文件

1.1:生成进程core文件

sudo gdb -p <PID>

. . .bunch of info. . .

(gdb)gocre /tmp/jvm.core

  Saved corefile /tmp/jvm.core

(gdb) detach

(gdb) quit

1.2:根据core文件生成java heap文件

sudo jmap -dump:format=b,file=/tmp/jvm.hprof /usr/bin/java (自己机器java路径) /tmp/jvm.core

2:运行MAT找出内存泄漏根源(MAT下载:https://www.eclipse.org/mat/downloads.php

点击finish,然后就可以看到当前java进程的堆栈信息。

4:常用的查看java进程堆栈信息命令

JVM学习----查看堆栈信息这篇文章较全面的写了jstat、jmap的详细用法,下面我列举自己常用的一些命令:

每3秒钟输出一次当前进程已使用空间占总空间的百分比

命令:jstat -gcutil <PID>  3000

打印进程堆存活的各个对象个数和所占大小

命令:jmap -histo:live <PID> | more

使用jcmd不加任何参数即可获取jvm进程列表

命令:jcmd

使用jcmd help能够获取某个jvm进程其他可用的诊断命令

命令:jcmd <PID> help

它所列举的commands都是可以使用的。

5:参考文章相关链接:

Java Performance Tuning Guide:http://java-performance.info/

JVM学习----查看堆栈信息:https://blog.csdn.net/eos2009/article/details/78522901

JVM’s heap:https://www.atlassian.com/blog/archives/so-you-want-your-jvms-heap

JAVA性能优化工具小记的更多相关文章

  1. 9个Java性能优化工具汇总

    本文来自blog.idrsolutions.com 1.NetBeans profiler NetBeans Profiler是一个模块化的添加,为NetBeans IDE提供分析功能,它是一个开源的 ...

  2. JVM——九大工具助你玩转Java性能优化

    本文转载自 http://www.importnew.com/12324.html 本文由 ImportNew - 陈 晓舜 翻译自 idrsolutions.欢迎加入翻译小组.转载请参见文章末尾的要 ...

  3. 九大工具助你玩转Java性能优化

    在这篇文章中,我会带着大家一起看一下9个可以帮助我们优化Java性能的工具.有一些我们已经在IDR Solutions中使用了,而另外一些有可能在个人项目中使用. NetBeans Profiler ...

  4. Java性能优化的9大工具

    在这篇文章中,我会带着大家一起看一下9个可以帮助我们优化Java性能的工具.有一些我们已经在IDR Solutions中使用了,而另外一些有可能在个人项目中使用. NetBeans Profiler ...

  5. Java 性能分析工具 , 第 2 部分:Java 内置监控工具

    引言 本文为 Java 性能分析工具系列文章第二篇,第一篇:操作系统工具.在本文中将介绍如何使用 Java 内置监控工具更加深入的了解 Java 应用程序和 JVM 本身.在 JDK 中有许多内置的工 ...

  6. 《Java性能优化权威指南》

    <Java性能优化权威指南> 基本信息 原书名:Java performance 原出版社: Addison-Wesley Professional 作者: (美)Charlie Hunt ...

  7. 推荐:Java性能优化系列集锦

    Java性能问题一直困扰着广大程序员,由于平台复杂性,要定位问题,找出其根源确实很难.随着10多年Java平台的改进以及新出现的多核多处理器,Java软件的性能和扩展性已经今非昔比了.现代JVM持续演 ...

  8. Java 性能优化的五大技巧

    要对你的 Java 代码进行优化,需要理解 Java 不同要素之间的相互作用,以及它是如何与其运行时的操作系统进行交互的.使用下面这五个技巧和资源,开始学习如何分析和优化你的代码吧. 在我们开始之前, ...

  9. 【转】10种简单的Java性能优化

    10种简单的Java性能优化 2015/06/23 | 分类: 基础技术 | 14 条评论 | 标签: 性能优化 分享到: 本文由 ImportNew - 一直在路上 翻译自 jaxenter.欢迎加 ...

随机推荐

  1. Django框架-模型层

    Django框架-模型层 一.单表查询之必知必会13条 1.时间字段中的两个关键性参数 create_time = models.DateField() # 年月日 create_time = mod ...

  2. 推荐一个手机端切换地址gps的app

    在写脚本的时候遇到的 客户提供了这个app 免费 自身可以防检测 苹果和安卓都可以使用   官网 http://www.daniu.net/   搜索 大牛 或者danniu即可

  3. Java面向对象编程 -6.6

    数组倒序 做法一:定义一个新的数组而后按照逆序的方式保存 public static void main(String[] args) { int arr[] = new int[] {1,2,3,4 ...

  4. 【音乐欣赏】《Running Away》 - Taska Black / DROELOE

    曲名:Runing Away 作者:Taska Black .DROELOE [00:00.000] Running with the speed of light [00:03.081] Illum ...

  5. Atcoder Beginner Contest151D(迷宫问题求任意两点最短路径的最大值,BFS)

    BFS可以求得最短路,DFS会找到从当前点到图中叶子结点的路径. #define HAVE_STRUCT_TIMESPEC #include<bits/stdc++.h> using na ...

  6. jmeter plugin manager安装插件

    https://jmeter-plugins.org/wiki/PluginsManager/ 以websocket 插件为例 先安装plugin manger 第二步:打开jmetre  optio ...

  7. 服务器部署网站后,公网ip可以访问,域名不能访问问题(稳)

    出现问题 这几天我网站已经部署到vps上,域名也备好案,想使用域名指向我们公网ip.指完发现用域名访问不了网站,但是公网ip可以.于是看了网上资料,好像是要清除浏览器DNS缓存,我清完没用.然后发现我 ...

  8. 201771010135 杨蓉庆《面对对象程序设计(java)》第十七周学习总结

    1.实验目的与要求 (1) 掌握线程同步的概念及实现技术: (2) 线程综合编程练习 一.理论知识 ⚫ 线程同步 (1)多线程并发运行不确定性问题解决方案:引入线 程同步机制,使得另一线程要使用该方法 ...

  9. github初使

    怎么说那,全英文,对于我这个英文水平不是很高的人来说有一定的影响,但是这也促使了我学习英语,而且里面一些大牛的发表也不少的是英文版的,我感觉我在英语方面的需求,由github来提升了,早就注册好了账号 ...

  10. 小杨排队(dp)

    链接:https://ac.nowcoder.com/acm/contest/3667/J 题目描述 小阳想要买个东西,然后就去了商店,发现进商店需要排队(生意太火爆!),然后就开始漫长的等待,他觉得 ...