2---JVM启动参数有哪些?

Posted on 2022-06-30 14:12  慢热并不是缺点  阅读(67)  评论(0编辑  收藏  举报

也要以说JVM启动的时候可以调整哪些参数,来进行调优。JVM 为垃圾收集器、堆大小和运行时编译器提供与平台相关的默认选择。

性能取决于堆的大小、应用程序维护的实时数据量以及可用处理器的数量和速度.。

下面是调优的一些参数 使用命令行操作的:

1:最大暂停暂停时间目标 -XX:MaxGCPauseMillis=<nnn> :垃圾收集器需要<nnn>毫秒或更短的暂停时间,垃圾收集器将调整堆大小及与其相关的其他参数。默认情况,没有最大暂停暂停时间目标。

2:吞吐量目标  -XX:GCTimeRatio=<nnn> :垃圾收集时间与应用程序时间的比率是 1 / (1 + <nnn>),另外 垃圾收集所花费的时间是年轻代和老年代收集的总时间。

3:GC日志  -XX:+PrintGCDetails 垃圾收集的诊断信息写入标准输出  -XX:+PrintGCTimeStamps 给日志添加时间戳

4:堆大小:在虚拟机初始化时,为堆保留了整个空间, -Xmx 设置保留空间的大小,也就是最大堆大小,  -Xms(初始堆大小)的值如果比保留空间的值小,则不是所有的保留空间都立即交给虚拟机,未给虚拟机的空间被标记为”虚拟“,那么堆的不同部分(老生代和新生代)可以根据需要增长到虚拟空间的极限。

5:设置老年代和新生代的比率:-XX:NewRatio=3  年轻代:老年化=1:3

6:选择垃圾收集器,也可叫作 选择GC算法  

  • 串行GC XX:+UseSerialGC

  • 并行GC XX:+UseParallelGC   并行压缩是并行GC的一个功能 默认启用 关闭使用-XX:-UseParallelOldGC

  • 并发GC -XX:+UseConcMarkSweepGC启用 CMS 收集器     -XX:+UseG1GC启用 G1 收集器 

7:指定GC日志文件 ‐Xloggc:gc.log

8:指定堆内存溢出时自动进行Dump  ‐XX:+HeapDumpOnOutOfMemoryError 18 ‐XX:HeapDumpPath=/usr/local/

9:指定默认的连接超时时间  ‐Dsun.net.client.defaultConnectTimeout=2000

‐Dsun.net.client.defaultReadTimeout=2000 

10:指定时区  ‐Duser.timezone=GMT+08

11: 设置默认的文件编码为UTF‐8  ‐Dfile.encoding=UTF‐8

 附加一个小实践:使用G1启动一个hello程序

java ‐XX:+UseG1GC ‐Xms4g ‐Xmx4g ‐Xloggc:gc.log ‐XX:+PrintGCDetails ‐XX:+PrintGCDateStamps Hello

参考:https://docs.oracle.com/javase/8/docs/technotes/guides/vm/gctuning/toc.html

查看JVM进程号:使用命令jps , 找到进程号可以使用jstack pid 来查看线程栈 

使用jmap可以查看物理内存占用情况

Copyright © 2024 慢热并不是缺点
Powered by .NET 8.0 on Kubernetes