本文主要了解下面内容:
1、JVM常用的配置参数如、内存配置参数、GC策略配置参数、日志配置参数、异常信息参数。
2、通过一些辅助指令可以帮助我们查找参数的指令,以及在运行期间查看和更改一些参数配置。
3、常用的一些应用启动参数,在项目启动的时候我们需要配置哪些参数。
4、各种部署场景下通过什么方式配置这些参数。
一、堆内存相关配置
设置堆初始值
二、方法区内存配置常用参数
三、线程栈内存配置常用参数
每个线程栈最大值
指令1
注意:
栈设置太大,会导致线程创建减少。
栈设置小,会导致深入不够,深度的递归会导致栈溢出。
建议栈深度设置在3000-5000
四、配置垃圾收集器
Serial垃圾收集器
五、GC策略配置
GC并行执行线程数
-
新生代可容纳的最大对象
-
进入老年代的GC年龄
进入老年代最小的GC年龄
六、GC日志信息配置
配置GC文件路径
-
滚动生成日志
日志文件达到一定大小后,生成另一个文件。须配置Xloggc
开启
打印详细的GC日志
打印GC的详细日志,并且在程序运行结束是会打印出JVM的内存占用情况
开启
打印应用暂停时间
开启
每次GC完成后,打印出JVM堆内存每个区域的使用情况
开启
打印存活实例年龄信息
开启
七、条件触发配置
OutOfMemory异常时输出文件
抛出内存溢出错误时导出堆信息到指定文件
开启
在Full GC时生成dump文件
-
JAVA_OPTS
八、辅助指令
查看或修改正在运行的JVM 某项配置
指令格式:jinfo -flag 参数 进程号
1、查看HeapDumpOnOutOfMemoryError 配置是否开启
jinfo -flag HeapDumpOnOutOfMemoryError 870778
2、修改HeapDumpOnOutOfMemoryError 配置(-关闭 +开启)
jinfo -flag +HeapDumpOnOutOfMemoryError 870778
模糊查找指令
如果忘记了某个指令的全名,可根据部分单词匹配查找
java -XX:+PrintFlagsInitial |grep GC
查看JVM所有参数
java -XX:+PrintFlagsInitial
九、常用启动参数
1、设置堆内存大小
设置堆内存大小,Xms 最小内存,Xmx最大内存,不设置默认为物理机内存的四分之一。
-Xms2g -Xmx2g`
2、GC日志参数
生成GC滚动日志记录 ,当需要对GC排查问题时候需要对此日志分析。
-XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+UseGCLogFileRotation -XX:+PrintHeapAtGC -XX:NumberOfGCLogFiles=5 -XX:GCLogFileSize=20M -Xloggc:/opt/ard-user-gc-%t.log
-Xloggc:/opt/app/ard-user/ard-user-gc-%t.log 设置日志目录和日志名称
-XX:+UseGCLogFileRotation 开启滚动生成日志
-XX:NumberOfGCLogFiles=5 滚动GC日志文件数,默认0,不滚动
-XX:GCLogFileSize=20M GC文件滚动大小,需开启UseGCLogFileRotation
-XX:+PrintGCDetails 开启记录GC日志详细信息(包括GC类型、各个操作使用的时间),并且在程序运行结束打印出JVM的内存占用情况
-XX:+ PrintGCDateStamps 记录系统的GC时间
-XX:+PrintGCCause 产生GC的原因(默认开启)
3、异常时记录内存日志
抛出内存溢出错误时导出堆信息到指定文件,内存溢出时需要对此日志进行分析
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/data/dump/jvm.dump
HeapDumpOnOutOfMemoryError 异常后打印堆内存信息
HeapDumpPath 生成的堆内存日志的路径
十、各种场景的参数设置方式
Idea
![9b49ba87c4bdcf495426501484f493dc.png](https://img-blog.csdnimg.cn/img_convert/9b49ba87c4bdcf495426501484f493dc.png)
![574ba3410029f060b1e2519631011607.png](https://img-blog.csdnimg.cn/img_convert/574ba3410029f060b1e2519631011607.png)
Tomcat
linux 在tomcat 的bin目录下catalina.sh 文件里增加配置参数
JAVA_OPTS
![bbd4cc0473e4758d9c4afd12f39125ae.png](https://img-blog.csdnimg.cn/img_convert/bbd4cc0473e4758d9c4afd12f39125ae.png)
jar包
直接在启动命令跟对应参数
nohup
查看参数是否生效
jinfo -flag 参数 进程号
jinfo -flag HeapDumpOnOutOfMemoryError 1162