JIT编译参数
JIT编译器可以将运行时候的字节码编译成本地代码,从而提高运行效率,但是只有当一段代码被调用的次数超过JIT的编译阈值时,才会被编译成本地代码,下面就是设置这个阈值的参数:
-XX:CompileThreshold=2000 -XX:+PrintCompilation -XX:+CITime
- 代码表示,被调用2000千次,才会被编译为本地代码
- 但是,如果阈值设的太低,一些不常用的代码也会被编译,反而会浪费时间
OOM信息处理
如果程序出现内存溢出,可以将堆的信息导出来,并用Visual VM类似的工具看出问题所在,下面是内存溢出后,将堆信息导出来的方式,放入D盘
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=d:\m.hprof
- 当发生OOM错误时,还能调用第三方脚本,及时处理特殊情况,比如重启服务器
-XX:OnOutOfMemoryError=C:\reset.bat
打印GC相关的信息
开启简单的GC信息
-XX:PrintGC
详细的GC信息
- 拥有新生代、老年代以及永久区的GC信息
-XX:PrintGCDetails
加上发生时间
-XX:PrintGCTime
打印新生对象晋升老年代的阈值
-XX:+PrintTenuringDistribution
打印每次GC前后堆的信息
-XX:+PrintHeapAtGC
显示程序在GC停顿期间的执行时间
-XX:PrintGCApplication-StoppedTime
-XX:+PrintGCApplicationConcurrentTime
将以上信息保存在D盘
-Xloggc:C:\gc.log
其他
另外还有控制线程、使用大页、压缩指针等一些技巧,由于我没有用过,也就暂时不记录了……