Java 程序该怎么优化?(命令篇)
灵魂拷问,JDK 提供的命令,除了 java、javac,你还用过哪些命令呢?
灵魂再拷问,若你写的 Java 程序,出现了性能问题,该怎么去排查呢?
Java 作为编程语言中的战斗机,JDK 默认已经为我们提供了很多排查问题的工具,接下来就逐一认识认识。
1. jps
jps 命令,可以列出系统中所有运行 Java 进程,并可以查看 Java 进程的启动类、传入参数以及 JVM 参数等信息。
例如,在控制台输入 jps -lmv 命令,效果如下(截取部分内容)。
很显然,jps 背后是一个 Java 程序,列出了完整的类路径、传给 main 方法的参数,以及 JVM 的参数。
为了方便了解、查阅,对 jps 命令的参数进行大致的梳理。
另外,不要大惊小怪,jps 以及下面要提到的 JDK 的排查工具,本质都是 Java 程序。
2. jstat
jstat 命令,用于查看 Java 进程的堆使用情况以及 GC 情况。
例如,输出 Java 进程 90961 的类加载相关信息,每秒钟统计一次信息,一共输出 3 次。
控制台输入命令:jstat -class 90961 1000 3,效果如下。
各参数的含义,依次如下:
Loaded 表示载入了类的数量
Bytes 表示载入类的合计大小
Unloaded 表示卸载类的数量
Bytes 表示卸载类的大小
Time 表示在加载和卸载类上所花的时间
例如,显示 GC 相关的堆信息。
控制台输入命令:jstat -gc 90961,效果如下。
各参数的含义,依次如下:
S0C:s0(from)的大小,单位 KB。
S1C:s1(from)的大小,单位 KB。
S0U:s0(from)已使用的空间,单位 KB。
S1U:s1(from)已使用的空间,单位 KB。
EC:eden 区的大小,单位 KB。
EU:eden 区的使用空间,单位 KB。
OC:老年代大小,单位 KB。
OU:老年代已经使用的空间,单位 KB。
PC:永久区大小,单位 KB。
PU:永久区使用空间,单位 KB。
YGC:新生代 GC 次数。
YGCT:新生代 GC 耗时。
FGC:Full GC 次数。
FGCT:Full GC 耗时。
GCT:GC 总耗时。
例如,显示最近一次 GC 的原因及当前 GC 的原因。
控制台输入命令:jstat -gccause 90961,效果如下。
参数含义解释:
LGCC:上次 GC 的原因。
GCC:当前 GC 的原因。
另外,为了方便了解、查阅,对 jstat 命令的参数进行大致的梳理。
3. jinfo
jinfo 命令,可以帮我们查看正在运行的 Java 进程的扩展参数,并支持在运行时修改部分参数;可以很方便地帮我们找到 JVM 参数的当前值。
例如,查看 Java 进程 90961 是否开启打印 GC 详细信息。 命令:jinfo -flag PrintGCDetails 90961 例如,打开 Java 进程 90961 的 PrintGCDetails 开关。 命令:jinfo -flag +PrintGCDetails 90961 例如,关闭 Java 进程 90961 的 PrintGCDetails 开关。 命令:jinfo -flag -PrintGCDetails 90961
使用比较简单,就不贴效果啦。
另外,为了方便了解、查阅,对 jinfo 命令的参数也进行大致的梳理。
4. jmap
jmap 命令,可以帮我们生成 Java 进程的堆快照和对象的统计信息。
例如,生成 PID 为 90961 的 Java 进程的对象统计信息,并输出到 yyxj.txt 文件中。
控制台输入命令:jmap -histo 90961 > yyxj.txt,打开文件效果如下。
例如,生成 PID 为 90961 的 Java 进程的当前堆快照,输出到 heap.hprof 文件中。
命令:jmap -dump:format=b,file=heap.hprof 90961
对于输出的 heap.hprof 快照文件,可以使用 jhat、VisualVM 等工具打开查看。采用 VisualVM 工具查看,效果如下。
5. jhat
jhat 命令,用于分析 Java 程序的堆快照内容,并且在分析完成之后,启动一个 HTTP 服务,让我们可以通过浏览器查看 Java 堆快照信息。
例如,采用 jhat 分析上一步中 jmap 输出的堆快照文件。
输入命令:jhat heap.hprof,效果如下。
浏览器访问 http://127.0.0.1:7000,一探究竟。
另外,唯恐堆快照会比较大,jhat 还支持 OQL 语句查询堆快照信息,闲暇之余可参考帮助手册 http://127.0.0.1:7000/oqlhelp/ 进行深入了解。
6. jstack
jstack 命令,可以帮助我们导出 Java 程序的线程堆栈,并自动帮我们进行死锁检查,并输出找到的死锁信息。
例如,把 PID 为 92760 的 Java 进程的线程堆栈信息,输出保存到文件中。
命令:jstack -l 92760 > deadlock.txt,打开 deadlock.txt,进程的内部细节,一览无余,那么我们很容易,就能找到死锁。
7. 其它
本次提到的这些命令,建议有时间实操一遍,因为纸上得来终觉浅,绝知此事要躬行。
JDK 提供的排查问题的命令还有很多,时间关系,本次就不再一一列举。
后续会进行实战分析,看看如何把这些命令组合起来,去打一套好的组合拳出来,敬请期待。
Java 程序该怎么优化?(命令篇)的更多相关文章
- Java 程序该怎么优化?(工具篇)
程序员:为什么程序总是那么慢?时间都花到哪里去了? 面试官:若你写的 Java 程序,出现了性能问题,该怎么去排查呢? 工欲善其事必先利其器,为你呈上一箩筐性能优化工具,必有一款满足你,废话不多说,直 ...
- Java 程序该怎么优化?(实战篇)
面试官:出现了性能问题,该怎么去排查呢? 程序猿:接口响应那么慢,时间都花到哪里去了? 运维喵:为什么你的应用跑着跑着,CPU 就接近 100%? 分享一些真实生产问题排查故事,看看能否涨姿势,能否 ...
- Java 程序该怎么优化?(技巧篇)
搬砖者:为什么程序总是那么慢?它现在到底在干什么?时间都花到哪里去了? 面试官:简单谈谈 Java 程序性能优化? 1. 字符串处理优化,乃优化之源. 研发过程中,String 的 API 用的应该是 ...
- 如何在java程序中调用linux命令或者shell脚本
转自:http://blog.sina.com.cn/s/blog_6433391301019bpn.html 在java程序中如何调用linux的命令?如何调用shell脚本呢? 这里不得不提到ja ...
- 运行java程序的方法-DOS命令和Eclipse方法
● 运行java程序的方法(使用DOS命令) 首先进行一个"文件夹选项"的设置: 在D:\Android\java_code目录下新建了一个Hello_World.java文件(不 ...
- java程序员的NodeJS初识篇
摘要 作为一个一直用java来写后端的程序员用NodeJS来写后台,实在不是很爽.这里记下这两个月的NodeJS学习所遇之坑,与java转NodeJS的同仁共勉.学习时间不长,若有理解错误,望指正. ...
- java程序猿常用Linux命令
1.查找文件 find / -name filename.txt 根据名称查找/目录下的filename.txt文件. find . -name "*.xml" 递归查找所有的xm ...
- 写一段java程序来执行linux命令
摘要 在日常开发中,程序员需要经常查询服务器日志来排查问题和调试程序.如果是本地调试还好,但项目一旦发布到服务器上,每次查日志就很麻烦,而且日志量巨大,有时我们无法找到我们需要的信息.经常需要借助第三 ...
- 为何我建议1-3年的Java程序员仔细看看这篇文章
此文的目的是为了督促自己去不断学习,让自己有更明确的方向去提升自己.以技能树为基础,以面试要点为大纲,我觉得比抓住什么看什么要更有目的,更能坚持下去.世界瞬息万变,我们要时刻准备着.时刻提高着自己,才 ...
随机推荐
- 关于js拖放功能的实现
这是具体的拖放代码的HTML,里面依赖两个组件:EventUtil.js是兼容浏览器添加方法的库,EventTarget.js是一个发布-订阅者模式的对象库. EventUtil.js: var Ev ...
- 在Tomcat上发布Web项目的方式
一. Tomcat的使用: 安装:解压压缩包即可 注意:安装目录不能有中文 目录结构: ①bin:可执行文件 ②conf:可执行文件 ③lib:依赖的jar包 ④logs:日志文件 ⑤:temp:临时 ...
- webstorm破解 2020 最新更新
KNBB2QUUR1-eyJsaWNlbnNlSWQiOiJLTkJCMlFVVVIxIiwibGljZW5zZWVOYW1lIjoiZ2hib2tlIiwiYXNzaWduZWVOYW1lIjoiI ...
- RAC修改VIP地址
目录 当前环境 1.通过[srvctl config]确认当前VIP地址. 2.关闭dbconsole[对应的em] 3.关闭数据库实例 4.关闭asm实例 5.关闭结点服务 6.修改两个节点的/et ...
- JDK java version "1.8.0_181"环境搭建
1.从官网上下载jdk软件,本人的系统是32位 WIN10 所以只能装1.8.0_181的了.x86 2.下载完就按照提示安装就可以了,傻瓜式操作就不多说了. 3.配置环境环境变量 3.1 点击我的电 ...
- css hover 动画 transition:background-color 0.2s,color 0.2s; 外层套内层,正常是 里外层 鼠标上来 外层有hover,如果就想到里层hover触发外层hover,要用外层position 定义绝对定位,内层的hover跳出外层的div,这样视觉上就是两个单独的div,进行内外层联动。
css hover 动画 transition:background-color 0.2s,color 0.2s; 外层套内层,正常是 里外层 鼠标上来 外层有hover,如果就想到里层hover触发 ...
- React笔记1
目录 1.react基础:类组件.函数式组件.ES5/ES6继承 2.生命周期钩子函数 3.什么是JSX 4.props和state有什么区别 5.路由配置 6.自定义封住组件 7.React 状态管 ...
- stm32的hall库新建模板编译错误: #error "Please select first the target STM32F1xx device used in your application (in stm32f1xx.h file)"的处理
在stm32f1xx.h file文件中找到如下代码: /* Uncomment the line below according to the target STM32L device used i ...
- Fiddler5 发送HTTP请求
1.Fiddler Composer发送HTTP请求 Composer的编辑模式主要有2种:Parsed模式和Raw模式. 实例1:Composer发送get请求 实例2:Composer发送post ...
- CentOS7设置环境变量
目录 一.环境变量的概念 1.环境变量的含义 2.环境变量的分类 3.Linux环境变量 二.常用的环境变量 1.查看环境变量 2.常用的环境变量 三.设置环境量 1.系统环境变量 2.用户环境变量 ...