老司机常用JVM 启动参数解析

截取了生产服务器上的JVM启动参数,都是前人踩过无数坑总结出的精华。这里逐个介绍下

-server ①
-Xms512m ②
-Xmx1024m ③
-XX:PermSize=256m ④
-XX:MaxPermSize=512m ⑤

-XX:SurvivorRatio=6 ⑥
-XX:+DisableExplicitGC ⑦
-XX:MaxTenuringThreshold=5 ⑧
-XX:+UseConcMarkSweepGC ⑨
-XX:+UseParNewGC ⑩
-XX:+UseCMSCompactAtFullCollection ⑪
-XX:CMSFullGCsBeforeCompaction=5 ⑫
-XX:+UseCMSInitiatingOccupancyOnly ⑬
-XX:CMSInitiatingOccupancyFraction=70 ⑭
-XX:+PrintGC ⑮
-XX:+PrintGCDetails ⑯
-XX:+PrintGCDateStamps ⑰
-Xloggc:/tt/ttadmin/servers/axe_52500/logs/gc.log ⑱

-XX:+HeapDumpOnOutOfMemoryError ⑲
-XX:HeapDumpPath=/tt/ttadmin/servers/axe_52500/logs ⑳

-Dorg.apache.catalina.SESSION_COOKIE_NAME=axe_52500SESSIONID ㉑
-Djava.endorsed.dirs=/tt/ttadmin/webserver/tomcat/endorsed ㉒
-Dcatalina.base=/tt/ttadmin/servers/axe_52500 ㉓
-Dcatalina.home=/tt/ttadmin/webserver/tomcat ㉔

-Dfile.encoding=UTF-8 ㉕
-Doracle.jdbc.V8Compatible=true ㉖
-Djava.security.egd=file:/dev/./urandom ㉗
-Dsun.net.inetaddr.ttl=3 ㉘
-Djava.net.preferIPv4Stack=true ㉙

-Dcom.sun.management.jmxremote ㉚
-Dcom.sun.management.jmxremote.authenticate=false ㉛
-Dcom.sun.management.jmxremote.ssl=false ㉜
-Dcom.sun.management.jmxremote.port=52509 ㉝
-Djava.rmi.server.hostname=192.168.10.70 ㉞

org.apache.catalina.startup.Bootstrap
-config /tt/ttadmin/servers/axe_52500/conf/server.xml

======================================================

JVM实现:JDK6·JDK7:Oracle官方Hotspot

  • JRockit 从JDK7开始并入 Hotspot
  • OpenJDKHotspot 的开源子集,Hotspot 多了少量商业功能(没怎么用到过)
  • 从JDK8开始,PermGen (永久代)被 Metaspace (元空间) 替代


① -server 指定以服务模式启动

启动模式比较 client server
编译速度 快(10?%)
运行速度
默认资源占用
适用场景 GUI/脚本执行 服务器
32位支持
64位支持 ×

②-Xms512m 设置 堆内存 最小值/初始值

③-Xmx1024m 设置 堆内存 最大值

④-XX:PermSize=256m 设置 永久代 最小值/初始值

⑤-XX:MaxPermSize=512m 设置 永久代 最大值

  • 如果内存波动比较厉害,建议Xms设置同Xmx,JVM扩大内存会拖慢性能。
  • 永久代一般启动后是比较稳定的, 大量使用动态代理会占用更多永久代内存
  • JDK8开始方法区由元空间替代,相应参数为-XX:MetaspaceSize 和 -XX:MaxMetaspaceSize


⑥-XX:SurvivorRatio=6 设置老年代占堆内存的比例,默认老年代占8,新生代占2。增加新生代占比在较多即生即灭对象时(例如ETL任务),可以减少新生代的GC频率

⑦-XX:+DisableExplicitGC 禁止代码中的System.gc()

⑧-XX:MaxTenuringThreshold=5 设置晋升老年代的最大minor GC次数,默认值=最大值=15 实际晋升条件比较复杂,减小该值只能说一定程度上提高新生代的利用率,可能看不出效果

⑨-XX:+UseConcMarkSweepGC 使用CMS收集器收集老年代,特点是停顿短,停顿少。吞吐量相对低。适合短连接事务型系统

⑩-XX:+UseParNewGC 和上一条配合,年轻代使用并行GC

⑪-XX:+UseCMSCompactAtFullCollection 开启CMS压缩,解决碎片化问题。压缩会增加停顿,但是会减少FullGC频率。

⑫-XX:CMSFullGCsBeforeCompaction=5 CMS每5次Full GC进行一次压缩

⑬-XX:+UseCMSInitiatingOccupancyOnly CMS在一次GC后默认会自己预测计算下次启动GC的占比,据说有时候会导致频繁GC,所以开启后固定为下面的初始比例

⑭-XX:CMSInitiatingOccupancyFraction=70 CMS初始触发GC的占用比例

⑮-XX:+PrintGC 输出GC日志

⑯-XX:+PrintGCDetails 输出GC的详细日志

⑰-XX:+PrintGCDateStamps 输出GC的时间戳

⑱-Xloggc:/tt/ttadmin/servers/axe_52500/logs/gc.log GC文件的输出路径


⑲-XX:+HeapDumpOnOutOfMemoryError 内存溢出时保存当时的内存快照

⑳-XX:HeapDumpPath=/tt/ttadmin/servers/axe_52500/logs 内存溢出时保存当时的内存快照


㉑-Dorg.apache.catalina.SESSION_COOKIE_NAME=axe_52500SESSIONID 设置tomcat session的名字,解决同一域名下多应用session冲突的问题

㉒-Djava.endorsed.dirs=/tt/ttadmin/webserver/tomcat/endorsed 使用定制的实现替换JDK标准实现,主要是替换xml解析器

㉓-Dcatalina.base=/tt/ttadmin/servers/axe_52500 指定tomcat war包路径

㉔-Dcatalina.home=/tt/ttadmin/webserver/tomcat 指定tomcat启动命令路径

㉕-Dfile.encoding=UTF-8 修改JVM默认字符集,涉及到文件IO,class文件内的中文问题等。默认为系统字符编码,中文系统Windows常见为GBK


㉖-Doracle.jdbc.V8Compatible=true 修复oracle10g驱动对日期的处理流失时间问题

㉗-Djava.security.egd=file:/dev/./urandom 默认的随机数生成会阻塞,该配置改为非阻塞。用UUID的同学也会用到

㉘-Dsun.net.inetaddr.ttl=3 设置JVM缓存NDS时间,默认是永远有效,必须重启

㉙-Djava.net.preferIPv4Stack=true 优先使用IPv4地址


㉚-Dcom.sun.management.jmxremote 开始JMX

㉛-Dcom.sun.management.jmxremote.authenticate=false 关闭JMX认证

㉜-Dcom.sun.management.jmxremote.ssl=false 关闭JMX认证

㉝-Dcom.sun.management.jmxremote.port=52509 设置JMX端口

㉞-Djava.rmi.server.hostname=192.168.10.70 设置RMI主机名,避免127.0.0.1远程不认识

你可能感兴趣的:(老司机常用JVM 启动参数解析)