jvm-04

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
  • 不断选择垃圾收集器,然后观测吞吐量和停顿时间的最佳值
常用参数:

参数官方链接/附件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值