也要以说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可以查看物理内存占用情况
本文来自博客园,作者:慢热并不是缺点,转载请注明原文链接:https://www.cnblogs.com/angin-iit/p/16426709.html