1 基于JDK命令行工具的监控

1.1 JVM的参数类型

1.1.1 标准参数

  在JVM的各个版本基本上保持不变,很稳定的。

  -help

  -server -client

  -version -showversion

  -cp -classpath

1.1.2 X参数

  非标准化参数

  -Xint: 解释执行

  -Xcomp: 第一次使用就编译成本地代码

  -Xmixed: 混合模式,JVM自己来决定是否编译成本地代码

1.1.3 XX参数

  非标准化参数

  相对不稳定

  主要用于JVM调优和Debug

  Boolean类型

  格式:-XX:[+-]<name>表示启用或者禁用name属性

  比如:-XX:+UseConcMarkSweepGC

     -XX:+UseG1GC

  非Boolean类型

  格式:-XX:<name>=<value>表示name属性的值是value

  比如:-XX:MaxGCPauseMillis=500

     -XX:GCTimeRatio=19

  -Xmx  -Xms

  -Xms等价于-XX:InitialHeapSize

  -Xmx等价于-XX:MaxHeapSize

  

命令 作用
ps -ef|grep java 查看java的进程相关信息,以及启动的配置信息
jinfo -flag MaxHeapSize pid 查看该pid的JVM最大的堆内存大小
jinfo -flag ThreadStackSize pid 查看该pid的JVM每个线程的栈大小

1.2 运行时JVM参数查看

  -XX:+PrintFlagsInitial

    初始值

  -XX:+PrintFlagsFinal

    最终值

  

  =  表示默认值

  :=  被用户或者JVM修改后的值

  -XX:+UnlockExperimentalVMOptions  解锁实验参数

  -XX:+UnlockDiagnosticVMOptions    解锁诊断参数

  -XX:+PrintCommandLineFlags     打印命令行参数

  jps

  类似与Linux服务器上的ps功能。

  相关命令:

  jps -help  查看帮助

  jps -l  查看正在运行的列表

  jps命令详细介绍参考:https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jps.html

    jinfo命令详细介绍参考:https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jinfo.html#BCGEBFDD

  jstack命令详细介绍参考:https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jstack.html#BABGJDIF

  jmap命令详细介绍参考:https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jmap.html#CEGCECJB

  jinfo

  查看正在运行的JVM里面的参数值。

  相关命令:jinfo -flag MaxHeapSize pid  查看正在运行的进程为PID的JVM的最大堆内存

       jinfo -flags pid  查看正在运行的进程为PID的JVM的已经被修改过的JVM的参数值

  查看最大内存

  

  查看垃圾回收器

  

1.3 jstat查看虚拟机统计信息

    类装载

    jstat命令详细参考:https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jstat.html#BEHHGFAE

    参考命令:jstat -class pid  查看类加载的信息

         jstat -class pid 1000 10  每隔1000ms打印一次类加载信息,打印10次。

    垃圾收集

    参考命令:jstat -gc pid  查看进程号为pid的JVM的垃圾收集信息,具体响应详细参数jstat命令详细参考

         jstat -gc pid 1000 10  每隔1000ms打印一次进程号为pid的JVM的垃圾收集信息,打印10次。

    JIT编译

    参考指令:jstat -compiler pid  查看进程号为pid的JVM的即时编译信息。

2 Jmap+MAT实战内存溢出

2.1 模拟对内存溢出的代码参考:

  

2.2 如何导出内存映像文件

2.2.1 内存溢出自动导出

  程序启动的时候,设置以下参数

  -XX:+HeapDumpOnOutOfMemoryError

  -XX:HeapDumpPath=./

2.2.2 使用jmap命令手动导出

  jmap -dump:format=b,file=heap.hprof pid  导出进程号为pid的JVM的dump文件

  jmap -heap pid               打印进程号为pid的JVM的堆信息

  jmap命令

  option: -heap, -clstats, -dump:<dump-options>, -F

  更多详细命令参考:jmap命令详细介绍参考:https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jmap.html#CEGCECJB

2.3 MAT分析内存溢出

  MAT工具下载地址:http://www.eclipse.org/mat/downloads.php

  将步骤2.2导出的dump文件,用MAT工具打开分析。  

2.4 JAVA线程状态

  NEW  WAITING  RUNNABLE  TIMED_WAITING  BLOCKED  TERMINATED

  更多详细信息参考:https://docs.oracle.com/javase/8/docs/technotes/guides/troubleshoot/tooldescr034.html

3 实战死循环导致CPU飙高

  查找死循环导致CPU飙高问题的常用指令:

    top -p pid -H          #打印该进程的所有线程,查看占用CPU资源超高的线程ID,该线程ID为10进制,要用下面的命令将其转换为16进制,然后在stack信息中查找详细信息

    printf "%x" 十进制的线程id    #将十进制的线程id转换为16进制

    jstack pid               #打印程序的stack信息,从中找出CPU占用超过的线程ID的stack信息

  也可以参考:https://www.cnblogs.com/alsodzy/p/10188691.html,来排查CPU飙高的问题。

Java虚拟机性能监控与调优的更多相关文章

  1. Java虚拟机性能监控与调优实战

    From:  https://c.m.163.com/news/a/D7B0C6Q40511PFUO.html?spss=newsapp&fromhistory=1 Java虚拟机性能监控与调 ...

  2. Java项目性能监控和调优工具-Javamelody的学习总结

    1.简介: JavaMelody能够在运行环境监测Java或Java EE应用程序服务器.并以图表的形式显示:Java内存和Java CPU使用情况,用户Session数量,JDBC连接数,和http ...

  3. JAVA性能监控与调优参考文档链接

    JAVA性能监控与调优参考文档链接 jdk8工具集 https://docs.oracle.com/javase/8/docs/technotes/tools/unix/index.htmlTroub ...

  4. Java生产环境下性能监控与调优详解

    1:JVM字节码指令与 javapjavap <options> <classes>cd monitor_tuning/target/classes/org/alanhou/m ...

  5. Java生产环境下性能监控与调优详解视频教程 百度云 网盘

    集数合计:9章Java视频教程详情描述:A0193<Java生产环境下性能监控与调优详解视频教程>软件开发只是第一步,上线后的性能监控与调优才是更为重要的一步本课程将为你讲解如何在生产环境 ...

  6. <JVM下篇:性能监控与调优篇>补充:使用OQL语言查询对象信息

    笔记来源:尚硅谷JVM全套教程,百万播放,全网巅峰(宋红康详解java虚拟机) 同步更新:https://gitee.com/vectorx/NOTE_JVM https://codechina.cs ...

  7. <JVM下篇:性能监控与调优篇>补充:浅堆深堆与内存泄露

    笔记来源:尚硅谷JVM全套教程,百万播放,全网巅峰(宋红康详解java虚拟机) 同步更新:https://gitee.com/vectorx/NOTE_JVM https://codechina.cs ...

  8. <JVM下篇:性能监控与调优篇>03-JVM监控及诊断工具-GUI篇

    笔记来源:尚硅谷JVM全套教程,百万播放,全网巅峰(宋红康详解java虚拟机) 同步更新:https://gitee.com/vectorx/NOTE_JVM https://codechina.cs ...

  9. <JVM下篇:性能监控与调优篇>01-概述篇-02-JVM监控及诊断工具-命令行篇

    笔记来源:尚硅谷JVM全套教程,百万播放,全网巅峰(宋红康详解java虚拟机) 同步更新:https://gitee.com/vectorx/NOTE_JVM https://codechina.cs ...

随机推荐

  1. Bootstrap学习--基本格式

    以下为Bootstrap的基本格式代码 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta ...

  2. nodejs 几篇有用的文章

    深入浅出Node.js(三):深入Node.js的模块机制 http://www.infoq.com/cn/articles/nodejs-module-mechanism Node.js简单介绍并实 ...

  3. 记事本APP之Alpha报告

    项目名称 记事本APP 项目版本 Alpha版本 负责人 北京航空航天大学计算机学院 Echo软件团队 联系方式 http://www.cnblogs.com/echo-buaa/ 要求发布日期 20 ...

  4. 第三次博客作业JSF

    JSF规格化设计发展史以及为什么得到人们重视 查阅了n多资料但是仍然没找到. 就说一些jsf的优势吧. 优势:    (1)UI组件 (2)事件驱动模式 (3)用户界面到业务逻辑的直接映射 (4)程序 ...

  5. 20172319 2018.03.27-04.05 《Java程序设计》第4周学习总结

    20172319 2018.03.27-04.05 <Java程序设计>第4周学习总结 教材学习内容总结 第四章 编写类 类与对象的回顾:对象是有状态的,状态由对象的属性值确定.属性由类中 ...

  6. CS小分队第二阶段冲刺站立会议(6月2日)

    昨日成果:攻克了按钮移动的问题: 遇到问题:一开始按钮移动时候,非常慢,因为是根绝相对位移差来移动,延时很严重,后来改用用鼠标的位置作为按钮的移动位置,效果明显. 按钮的mousedown事件和mou ...

  7. (2016.2.2)1001.A+B Format (20)解题思路

    https://github.com/UNWILL2LOSE/object-oriented 解题思路 目标: *首先运算要求实现输入2个数后,输出类似于银行的支票上的带分隔符规则的数字. 代码实现思 ...

  8. 20_集合_第20天(Map、可变参数、Collections)_讲义

    今日内容介绍 1.Map接口 2.模拟斗地主洗牌发牌 01Map集合概述 A:Map集合概述: 我们通过查看Map接口描述,发现Map接口下的集合与Collection接口下的集合,它们存储数据的形式 ...

  9. 解决getOutputStream() has alerady been called for this response

    在用tomcat启动一个web项目(SpringBoot)的时候报错: getOutputStream() has alerady been called for this response 但是如果 ...

  10. Python模块Scrapy导入出错:ImportError: cannot import name xmlrpc_client

    Mac(OS version: OS X Yosemite 10.10.5)上安装Scrapy模块,使用时出现: from six.moves import xmlrpc_client as xmlr ...