jvm参数调优需要调哪些参数?
1.调内存参数:堆、栈、永久代 注意事项:最小堆内存和最大堆内存要设置一样,防止内存回落,进行垃圾收集;堆内存要结合操作系统的内存大小进行设置
2.垃圾收集器 jvm调优方案:
1.在开发工具中直接调或者通过配置tomcat
2.去tomcat的安装目录的bin目录下的catalina.bat配置文件(catalina.sh是Linux系统的)
3.通过dos窗口通过java命令 java -Xmx1024m -version 如果显示版本号,说明可以使用1024m的虚拟机内存,如果不显示版本号,则不能使用 jvm监控: 1.Windows中使用jdk安装目录/bin下的jconsole.exe/jvisual.exe 2.Linux中使用命令查看该jvm的内存使用情况、线程情况等等
主要参数调优配置信息: -server -Xms3G -Xmx3G -Xss256k -XX:PermSize=128m -XX:MaxPermSize=128m -XX:+UseParallelOldGC -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/usr/aaa/dump -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -Xloggc:/usr/aaa/dump/heap_trace.txt -XX:NewSize=1G -XX:MaxNewSize=1G 说明: -server 以server模式启动 -Xms3G 最小堆内存是3G -Xmx3G 最大对内存是3G -Xss256k 栈内存是256k -XX:PermSize=128m 永久代内存是128m -XX:MaxPermSize=128m 永久代最大内存是128m -XX:+UseParallelOldGC 使用的垃圾收集器 剩下的是垃圾收集器的配置
jvm参数调优参数配置详解
//堆设置
-Xms:初始堆大小
-Xmx:最大堆大小
-XX:NewSize=n:设置年轻代大小
-XX:NewRatio=n:设置年轻代和年老代的比值.如:为3,表示年轻代与年老代比值为1:3,年轻代占整个年轻代年老代和的1/4
-XX:SurvivorRatio=n:年轻代中Eden区与两个Survivor区的比值.注意Survivor区有两个.如:3,表示Eden:Survivor=3:2,一个Survivor区占整个年轻代的1/5
-XX:MaxPermSize=n:设置持久代大小 //收集器设置 -XX:+UseSerialGC:设置串行收集器 -XX:+UseParallelGC:设置并行收集器 -XX:+UseParalledlOldGC:设置并行年老代收集器 -XX:+UseConcMarkSweepGC:设置并发收集器
//垃圾回收统计信息 -XX:+PrintGC -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -Xloggc:filename //并行收集器设置 -XX:ParallelGCThreads=n:设置并行收集器收集时使用的CPU数.并行收集//线程数. -XX:MaxGCPauseMillis=n:设置并行收集最大暂停时间 -XX:GCTimeRatio=n:设置垃圾回收时间占程序运行时间的百分比.公式为1/(1+n) //并发收集器设置 -XX:+CMSIncrementalMode:设置为增量模式.适用于单CPU情况. -XX:ParallelGCThreads=n:设置并发收集器年轻代收集方式为并行收集时,使用的CPU数.并行收集线程数.