JVM性能调优命令
记一次JVMFullGC(MetadataGCThreshold)调优经历

记⼀次JVMFullGC(MetadataGCThreshold)调优经历记⼀次JVM Full GC (Metadata GC Threshold)调优经历⼀、背景:线上服务器内存使⽤超过90%,分析上⾯部署的各个服务的GC⽇志,发现有⼀个服务的JVM内存分配过⼤,使⽤率较低,有调优的空间,可以在不迁移服务或者不升级服务器配置的情况下,降低服务器内存占⽤。
JVM推荐配置原则:应⽤程序运⾏时,计算⽼年代存活对象的占⽤空间⼤⼩X。
程序整个堆⼤⼩(Xmx和Xms)设置为X的3 ~ 4倍;永久代PermSize和MaxPermSize设置为X的1.2 ~ 1.5倍。
年轻代Xmn的设置为X的1 ~ 1.5倍。
⽼年代内存⼤⼩设置为X的2 ~ 3倍。
JDK官⽅建议年轻代占整个堆⼤⼩空间的3/8左右。
完成⼀次Full GC后,应该释放出70%的堆空间(30%的空间仍然占⽤)。
观察线上发现2G的堆内存,Full GC之后的活跃对象才占⽤60M。
按照推荐设置JVM内存只需要给⼏百M就好了。
所以决定改成1G,既能够降低服务器内存占⽤,也预留了⾜够的业务增长空间。
在这个过程中,发现如下⼏个问题:GC⽇志没有时间显⽰,看起来很不⽅便GC⽇志没有滚动,时间久了,⽇志⽂件较⼤GC⽇志中存在⼤量Full GC (Metadata GC Threshold)显然第三个问题最为严重。
我们知道,元数据区主要是⽤来存储类的元数据的。
⼀般来讲,类加载完成之后,⼤⼩应该是⽐较稳定的,不会有太⼤变动。
所以可以判断,这么频繁的Full GC (Metadata GC Threshold),肯定是哪⾥出问题了。
但是我们⼀步⼀步来解决问题,⽽且GC⽇志不够详细也影响我们定位问题。
⼆、优化GC⽇志打印⾸先复习⼀下JVM的GC⽇志打印的启动参数。
详见-verbose:gc同-XX:+PrintGC-XX:+PrintGC最简单的 GC 参数会打印 GC 前后堆空间使⽤情况以及 GC 花费的时间-XX:+PrintGCDetails打印GC的详细信息,会打印 youngGC FullGC前后堆【新⽣代,⽼年代,永久区】的使⽤情况以及 GC 时⽤户态 CPU 耗时及系统CPU 耗时及 GC 实际经历的时间-XX:+PrintGCTimeStamps打印CG发⽣的时间戳,从应⽤启动开始累计的时间戳-XX:+PrintGCDateStamps打印GC发⽣的时刻,所处⽇期时间信息-Xloggc:gc.log指定GC log的位置,以⽂件输出-XX:+PrintHeapAtGC每⼀次GC前和GC后,都打印堆信息。
《Java性能调优指南》

《Java性能调优指南》随着互联网的飞速发展,Java作为一种重要的编程语言,被越来越广泛地应用于各个领域。
但是,Java程序的性能问题也随之出现。
如何调优Java 程序的性能,成为了每个开发人员需要解决的难题。
本文将为大家介绍Java性能调优的指南。
一、JVM参数设置JVM(Java虚拟机)参数设置是Java性能调优的关键。
JVM有众多的参数,不同的参数设置会对Java程序的性能产生不同的影响。
常用的JVM参数设置包括以下几个方面:1. 内存设置内存是Java程序的一大瓶颈。
如果内存设置不合理,会导致Java程序频繁地进行垃圾回收,造成程序的延迟和不稳定。
在设置内存参数时需要注意以下几点:- -Xmx: 最大堆内存,设置合理的最大堆内存大小可以减少JVM的垃圾回收次数,提高程序性能。
- -Xms: 初始堆内存,设置合理的初始堆内存大小可以加快程序启动时间,提高程序性能。
- -XX:NewRatio: 新生代与老年代的比例,如果设置得当,可以减少垃圾回收的次数。
通常新生代的大小为总堆容量的1\/3或1\/4,老年代的大小为总堆容量的2\/3或3\/4。
2. 垃圾回收设置垃圾回收是Java程序中必不可少的一部分。
合理的垃圾回收参数设置可以提高程序性能。
常用的垃圾回收参数设置包括以下几点:- -XX:+UseParallelGC: 使用并行GC,适用于多核CPU。
- -XX:+UseConcMarkSweepGC: 使用CMS GC,适用于大型Web应用程序。
- -XX:+UseG1GC: 使用G1 GC,适用于大内存应用程序。
3. JIT设置JIT(即时编译器)是Java程序中非常重要的一部分。
合理的JIT参数设置可以提高程序的性能。
常用的JIT参数设置包括以下几点:- -XX:+TieredCompilation: 启用分层编译,可以提高程序启动时间和性能。
- -XX:CompileThreshold: JIT编译阈值,设置JIT编译的最小方法调用次数,可以提高程序性能。
Java生产环境下性能监控与调优详解

Java⽣产环境下性能监控与调优详解1:JVM字节码指令与 javapjavap <options> <classes>cd monitor_tuning/target/classes/org/alanhou/monitor_tuning/chapter8/javap -verbose Test1.class > Test1.txt 即可保存字节码⽂件会有三个部分组成操作数栈LineNumberTableLocalVariableTablei++和++i 的执⾏效果完全相同多了⼀个压⼊栈顶操作for(int i=0;i<10;i++) {}for(int i=0;i<10;++i) {} 执⾏效果⼀样2:public static void f1() {String src = "";for(int i=0;i<10;i++) {//每⼀次循环都会new⼀个StringBuilder 然后在src.append("A");src = src + "A";}System.out.println(src);}public static void f2() {//只要⼀个StringBuilderStringBuilder src = new StringBuilder();for(int i=0;i<10;i++) {src.append("A");}System.out.println(src);}3:public static String f1() {String str = "hello";try{return str;}finally{str = "imooc";}} 返回 hello 但会执⾏finally 中的代码4:字符串拼接都会在编译阶段转换成stringbuilder5:字符串去重字符串在任何应⽤中都占⽤了⼤量的内存。
java jvm参数

java jvm参数
Java 虚拟机(JVM)参数是用来配置 Java 虚拟机运行时环境的一组参数。
它们可以用来控制 JVM 的内存使用情况,调整垃圾回收器的行为,debugging,启用额外的错误检查等等。
1、-Xms:设置JVM初始内存大小,默认是物理内存的1/64。
2、-Xmx:设置JVM最大可用内存大小,一般设置为物理内存的1/4或1/8。
3、-Xss:设置JVM单个线程栈内存大小,通常为
512K到1024K之间。
4、-XX:+UseSerialGC:开启串行垃圾收集器,使用单线程工作,可以提高性能,但是应用程序也会受到影响。
5、-XX:+PrintGCDetails:打印出垃圾回收的详细信息,方便进行性能调优。
6、-XX:MaxPermSize:设置持久代的最大内存大小,默认情况下,持久代的内存大小取决于MaxHeapSize的值。
7、-XX:NewRatio:设置新生代和老年代的比例,默认情况下是2,即新生代是老年代的一半。
8、-XX:SurvivorRatio:设置Eden区和Survivor区的比例,默认情况下是8,即Eden区是Survivor区的八分之一。
JVM调优总结 -Xms -Xmx -Xmn -Xss1

1.堆大小设置JVM 中最大堆大小有三方面限制:相关操作系统的数据模型(32-bt还是64-bit)限制;系统的可用虚拟内存限制;系统的可用物理内存限制。
32位系统下,一般限制在1.5G~2G;64为操作系统对内存无限制。
我在Windows Server 2003 系统,3.5G物理内存,JDK5.0下测试,最大可设置为1478m。
典型设置:2.java -Xmx3550m -Xms3550m -Xmn2g-Xss128k-Xmx3550m:设置JVM最大可用内存为3550M。
-Xms3550m:设置JVM促使内存为3550m。
此值可以设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存。
-Xmn2g:设置年轻代大小为2G。
整个堆大小=年轻代大小 + 年老代大小 + 持久代大小。
持久代一般固定大小为64m,所以增大年轻代后,将会减小年老代大小。
此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8。
-Xss128k:设置每个线程的堆栈大小。
JDK5.0以后每个线程堆栈大小为1M,以前每个线程堆栈大小为256K。
更具应用的线程所需内存大小进行调整。
在相同物理内存下,减小这个值能生成更多的线程。
但是操作系统对一个进程内的线程数还是有限制的,不能无限生成,经验值在3000~5000左右。
java -Xmx3550m -Xms3550m -Xss128k -XX:NewRatio=4 -XX:SurvivorRatio=4 -XX:MaxPermSize=16m -XX:MaxTenuringThreshold=0-XX:NewRatio=4:设置年轻代(包括Eden和两个Survivor区)与年老代的比值(除去持久代)。
设置为4,则年轻代与年老代所占比值为1:4,年轻代占整个堆栈的1/5-XX:SurvivorRatio=4:设置年轻代中Eden区与Survivor区的大小比值。
设置为4,则两个Survivor区与一个Eden区的比值为2:4,一个Survivor区占整个年轻代的1/6-XX:MaxPermSize=16m:设置持久代大小为16m。
IntelliJIDEA设置JVM运行参数的操作方法

IntelliJIDEA设置JVM运⾏参数的操作⽅法打开 IDEA 安装⽬录,看到有⼀个 bin ⽬录,其中有两个 vmoptions ⽂件,需针对不同的JDK进⾏配置:32 位:idea.exe.vmoptions64 位:idea64.exe.vmoptions-Xms512m-Xmx1024m-XX:MaxPermSize=512m-XX:ReservedCodeCacheSize=225m-XX:+UseConcMarkSweepGC-XX:SoftRefLRUPolicyMSPerMB=50-eaeCanonCaches=false.preferIPv4Stack=true上⾯列出的是idea64.exe.vmoptions的默认内容,我们可以根据需要进⾏修改。
各参数的含义分别为:⼀、设置JVM内存设置1. 设置JVM内存的参数有四个:-Xmx Java Heap最⼤值,默认值为物理内存的1/4,最佳设值应该视物理内存⼤⼩及计算机内其他内存开销⽽定;-Xms Java Heap初始值,Server端JVM最好将-Xms和-Xmx设为相同值,开发测试机JVM可以保留默认值;-Xmn Java Heap Young区⼤⼩,不熟悉最好保留默认值;-Xss 每个线程的Stack⼤⼩,不熟悉最好保留默认值;2. 如何设置JVM内存分配:(1)当在命令提⽰符下启动并使⽤JVM时(只对当前运⾏的类Test⽣效):java -Xmx128m -Xms64m -Xmn32m -Xss16m Test(2)当在集成开发环境下(如eclipse)启动并使⽤JVM时:a. 在eclipse根⽬录下打开eclipse.ini,默认内容为(这⾥设置的是运⾏当前开发⼯具的JVM内存分配):-vmargs-Xms40m-Xmx256m-vmargs表⽰以下为虚拟机设置参数,可修改其中的参数值,也可添加-Xmn,-Xss,另外,eclipse.ini内还可以设置⾮堆内存,如:-XX:PermSize=56m,-XX:MaxPermSize=128m。
JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解

JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解J DK本身提供了很多方便的JVM性能调优监控工具,除了集成式的VisualVM和jConsole外,还有jps、jstack、jmap、jhat、jstat、hprof等小巧的工具,本博客希望能起抛砖引玉之用,让大家能开始对JVM性能调优的常用工具有所了解。
现实企业级Java开发中,有时候我们会碰到下面这些问题:OutOfMemoryError,内存不足内存泄露线程死锁锁争用(Lock Contention)Java 进程消耗CPU过高......这些问题在日常开发中可能被很多人忽视(比如有的人遇到上面的问题只是重启服务器或者调大内存,而不会深究问题根源),但能够理解并解决这些问题是Java程序员进阶的必备要求。
本文将对一些常用的JVM 性能调优监控工具进行介绍,希望能起抛砖引玉之用。
A、jps(Java Virtual Machine Process Status Tool) jps 主要用来输出JVM中运行的进程状态信息。
语法格式如下:jps[options] [hostid]如果不指定hostid就默认为当前主机或服务器。
命令行参数选项说明如下:-q 不输出类名、Jar名和传入main方法的参数-m 输出传入main 方法的参数-l 输出main类或Jar的全限名-v 输出传入JVM的参数比如下面:root@ubuntu:/# jps -m -l2458org.artifactory.standalone.main.Main /usr/local/artifactory-2.2.5/etc/jetty.xml29920 com.sun.tools.hat. Main -port 9998 /tmp/dump.dat3149 org.apache.catalina.startup.Boo tstrap start30972 sun.tools.jps.Jps -m -l8247 org.apache.catalin a.startup.Bootstrap start25687com.sun.tools.hat.Main -port 9999 dump.dat21711 mrf-center.jarB、jstack jstack主要用来查看某个Java进程内的线程堆栈信息。
jvm debug 参数

jvm debug 参数JVM是Java虚拟机的缩写。
JVM起着Java程序的运行环境之作用,因此JVM的性能直接影响程序运行的效率。
在开发Java应用程序的过程中,当出现异常情况时,需要借助JVM的debug参数来进行程序的调试和故障排查。
下面我们来详细了解一下JVM debug参数的使用方法。
第一步:开启JVM debug模式在Tomcat这样的应用程序中,我们可以在启动的时候通过设置JAVA_OPTS参数来开启JVM debug模式。
具体操作方法如下:1. 进入Tomcat安装目录中的bin目录,找到catalina.bat文件(Windows系统)或catalina.sh文件(Linux系统)。
2. 打开文件,找到JAVA_OPTS参数,修改为如下参数:JAVA_OPTS="-server -XX:+HeapDumpOnOutOfMemoryError -Xms512m -Xmx1024m -Xdebug -Xrunjdwp:transport=dt_socket,address=8080,server=y,suspend=n"以上参数中,“transport=dt_socket”表示调试连接的通信协议,“address=8080”表示调试连接的端口号,“server=y”表示开启服务器模式,允许多个调试连接,“suspend=n”表示不在启动时暂停Tomcat服务。
3. 保存文件并退出。
接下来重新启动Tomcat服务即可。
第二步:使用JVM debug参数调试应用程序当程序出现异常情况时,我们需要借助JVM debug参数来进行调试。
下面是具体操作步骤:1. 打开Eclipse或IntelliJ IDEA等集成开发环境,在调试模式下启动我们的应用程序。
同时,在Eclipse的Debug菜单中选择“Remote Java Application”项。
2. 在弹出的“Remote Java Application”对话框中填写连接参数。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
参数参数
值默
认值
参数含义
stack true 关闭对象分配调用栈跟踪。
如果分配位置信息在堆转储中不可用。
则必须将此标志设置为false。
refs true 关闭对象引用跟踪。
默认情况下,返回的指针是指向其他特定对象的对象。
如反向链接或输入引用,会统计/计算堆中的所有对象
port7000设置jhat HTTP server的端口号
exclude---指定对象查询时需要排除的数据成员列表文件
baseline---指定一个基准堆转储。
在两个heap dumps中有相同object ID的对象时,会被标记为不是新的,其他对象被标记为新的。
在比较两个不同的堆转储时很有用
debug0设置debug级别,0表示不输出调试信息。
值越大则表示输出更详细的debug信息
version---启动后只显示版本信息就退出
J---jhat命令实际上会启动一个JVM来执行,通过-J可以在启动JVM时传入一些启动参数。
例如, -J-Xmx512m则指定运行jhat 的Java虚拟机使用的最大堆内存为512MB。