jvm-04
发布日期:2021-05-08 05:28:16 浏览次数:19 分类:精选文章

本文共 2558 字,大约阅读时间需要 8 分钟。

jvm参数

  • 标准参数:不随着jdk的版本变化而发生变化,
    • 如java -version
    • java -help
  • -X 参数:随着jdk版本的变动而变动
    • 如:-Xint(运行期解释字节码并执行)
  • -XX参数
    • Boolean类型
      -XX:[+/-]name 启动或停止
    • 非Boolean类型
      • -XX:name = value
      • -XX:MaxHeapSize=100M
  • 其他参数[-XX参数]
    • -Xms100M ===>等同于 -XX:InitialHeapSize=100M
    • -Xmx100M ====> -XX:MaxHeapSize=100M
    • -Xss100k ===> -XX:ThreadStackSize=100k

查看参数

  • 查看所有: java -XX:+PrintFlagsFinal -version
    *查看某个:jinfo

参数修改:

  • idea、eclipse
  • 运行jar包的时候:java -XX:+UseG1GC xxx.jar
  • web容器比如tomcat,可以在脚本中的进行设置
  • 通过jinfo实时调整某个java进程的参数(参数只有被标记为manageable的flags可以被实时修改)

实践和单位换算

1Byte(字节)=8bit(位) 1KB=1024Byte(字节) 1MB=1024KB 1GB=1024MB 1TB=1024GB

常用命令

  • jps
    • 查看java进程
  • jinfo
    • 实时查看和调整jvm配置参数
    • 查看:jinfo -flag name PID(查看某个java进程的name属性的值)
      • jinfo -flag MaxHeapSize PID
      • jinfo -flag UseG1GC PID
    • 修改:参数只有被标志为manageable的flags可以被实时修改
      • jinfo -flag[+|-] PID
      • jinfo -flag = PID
    • 查看曾经赋值过的一些参数
      • jinfo -flag PID
  • jstat
    • 查看虚拟机性能统计信息
      • jstat -class PID 1000 10 查看某个java进程的类装载信息,每1000毫秒输出一次,共输出10 次
    • 查看垃圾收集信息
      • jstat -gc PID 1000 10
    • jstack
      • 查看进程堆栈信息
      • 用法 jstack PID
      • 排查死锁
      • 死锁代码:
        class MyLockObject{public static Object object1 = new Object();public static Object object2 = new Object();}public class DealLockDemo {    public static void main(String[] args) {        new Thread(()->{            while (true){                synchronized (MyLockObject.object1){                    System.out.println(Thread.currentThread().getName()+"获取到锁1");                    synchronized (MyLockObject.object2){                        System.out.println(Thread.currentThread().getName()+"获取锁2");                    }                }            }        }).start();        new Thread(()->{            while (true){                synchronized (MyLockObject.object2){                    System.out.println(Thread.currentThread().getName()+"获取到锁2");                    synchronized (MyLockObject.object1){                        System.out.println(Thread.currentThread().getName()+"获取锁1");                    }                }            }        }).start();    }}
  • jmap
    • 生成堆转储快照
    • 打印出堆内存相关信息
      • jmap -heap PID
    • dump出堆内存相关信息
      • jmap -dump:format=b,file=heap.hprof 44808
    • 在发生堆内存溢出的时候,自动dump出该文件
      • -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=heap.hprof

常用工具

  • jconsole

  • jvisualvm

    • 点击"线程" 如果有死锁,界面会提示“检测到死锁!”
    • 工具–>插件–>VisualGC–>可以查看Metaspce,新生代,老年代等实时图形化信息。
    • 监控远端Java进程(网上很多教程)
  • Arthas https://github.com/alibaba/arthas

  • Arthas 是Alibaba开源的Java诊断工具,采用命令行交互模式

  • Mat(相对比较强大的工具)

    • 可以点击Overview–>Reports–>Leak Suspects(内存泄漏猜测)
  • 在綫工具:console.perfma.com

GC日志分析工具

  • 打印GC日志:
    -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -Xloggc:gc.log
  • 在线工具:http://gceasy.io
    • GCView
  • 不断选择垃圾收集器,然后观测吞吐量和停顿时间的最佳值

常用参数:

上一篇:Apache Commons Lang3之StringUtils
下一篇:jvm-03

发表评论

最新留言

能坚持,总会有不一样的收获!
[***.219.124.196]2025年03月29日 10时18分52秒