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. python其他知识目录

    博客目录总纲首页 基础的重要性(程序员之路) 做一个“合格”的程序员(一)——基础能力 作为一个程序员,数学对你到底有多重要 同样是程序员,为什么别人比你更优秀? ------------------ ...

  2. cnblogs用户体验评价

    1. 是否提供良好的体验给用户(同时提供价值)? 博客园就相当于现在生活中处处可见的微博,所有人都在上面发表自己的一些看法,当然我们比较关注的是计算机编程方面的一些博客,大多数编程人员愿意分享自己的代 ...

  3. 编程之法section II: 2.1 求最小的k个数

    ====数组篇==== 2.1 求最小的k个数: 题目描述:有n个整数,请找出其中最小的k个数,要求时间复杂度尽可能低. 解法一: 思路:快排后输出前k个元素,O(nlogn). writer: zz ...

  4. 用原生JS实现多张图片上传及预览功能(兼容IE8)

    最近需要做一个图片上传预览的功能(兼容IE8-11.chrome.firefox等浏览器),网上现有的文件上传组件(如webuploader)总是会遇到一些兼容性问题.于是我参考了一些博文(链接找不到 ...

  5. Alpha阶段事后诸葛分析

    一.设想和目标 1.我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 我们的软件主要是解决在宿舍中购买商品的软件,不同于淘宝等软件,本软件主要是用于学生开设的店铺及宿 ...

  6. yii 验证码 CCaptcha的总结(转)

    今天用到yii的验证码 ccaptcha,经过在网上搜寻 找到以下例子: 1.在controller中加入代码 (1)启用 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 &l ...

  7. 将utf-8的中文或者字符都看成一个字符

    function utf8_strlen($string=null){ // 将字符串分解为单元 preg_match_all("/./us", $string, $match); ...

  8. [转帖]IBM POWER9 E950 and E980 Servers Launched

    IBM POWER9 E950 and E980 Servers Launched https://www.servethehome.com/ibm-power9-e950-and-e980-serv ...

  9. 通过jmap查看jvm采用的垃圾收集器

    1  tomcat 的PID获得 ps -ef|grep tomcat [root@iZ2zeapch8kbaw4bxnz8vxZ tomcat7]# ps -ef|grep tomcat root ...

  10. Dubbo学习(二) Dubbo 集群容错模式-负载均衡模式

    Dubbo是Alibaba开源的分布式服务框架,我们可以非常容易地通过Dubbo来构建分布式服务,并根据自己实际业务应用场景来选择合适的集群容错模式,这个对于很多应用都是迫切希望的,只需要通过简单的配 ...