JVM调优基础到进阶 (6)

比较一下这两段程序的异同,分析哪一个是更优的写法:

Object o = null; for(int i=0; i<100; i++) { o = new Object(); //业务处理 } for(int i=0; i<100; i++) { Object o = new Object(); }

重写finalize引发频繁GC
小米云,HBase同步系统,系统通过nginx访问超时报警,最后排查,C++程序员重写finalize引发频繁GC问题
为什么C++程序员会重写finalize?(new delete)
finalize耗时比较长(200ms)

如果有一个系统,内存一直消耗不超过10%,但是观察GC日志,发现FGC总是频繁产生,会是什么引起的?
System.gc() (这个比较Low)

Distuptor有个可以设置链的长度,如果过大,然后对象大,消费完不主动释放,会溢出 (来自 死物风情)

用jvm都会溢出,mycat用崩过,1.6.5某个临时版本解析sql子查询算法有问题,9个exists的联合sql就导致生成几百万的对象(来自 死物风情)

new 大量线程,会产生 native thread OOM,(low)应该用线程池,
解决方案:减少堆空间(太TMlow了),预留更多内存产生native thread
JVM内存占物理内存比例 50% - 80%

近期学生案例SQLLite的类库,批处理的时候会把所有的结果加载内存,有的人一下子更新几十万条数据,结果就产生了内存溢出,定位上用的是排除法,去掉这个模块就没问题,加上该模块就会出问题

java在线解压以及压缩文件造成的内存溢出

java使用opencv造成的卡顿与缓慢

最容易引起崩溃的报表系统

分库分表所引起的系统崩溃

GC常用参数

-Xmn -Xms -Xmx -Xss
年轻代 最小堆 最大堆 栈空间

-XX:+UseTLAB
使用TLAB,默认打开

-XX:+PrintTLAB
打印TLAB的使用情况

-XX:TLABSize
设置TLAB大小

-XX:+DisableExplictGC
System.gc()不管用 ,FGC

-XX:+PrintGC

-XX:+PrintGCDetails

-XX:+PrintHeapAtGC

-XX:+PrintGCTimeStamps

-XX:+PrintGCApplicationConcurrentTime (低)
打印应用程序时间

-XX:+PrintGCApplicationStoppedTime (低)
打印暂停时长

-XX:+PrintReferenceGC (重要性低)
记录回收了多少种不同引用类型的引用

-verbose:class
类加载详细过程

-XX:+PrintVMOptions

-XX:+PrintFlagsFinal -XX:+PrintFlagsInitial
必须会用

-Xloggc:opt/log/gc.log

-XX:MaxTenuringThreshold
升代年龄,最大值15

锁自旋次数 -XX:PreBlockSpin 热点代码检测参数-XX:CompileThreshold 逃逸分析 标量替换 ...
这些不建议设置

Parallel常用参数

-XX:SurvivorRatio

-XX:PreTenureSizeThreshold
大对象到底多大

-XX:MaxTenuringThreshold

-XX:+ParallelGCThreads
并行收集器的线程数,同样适用于CMS,一般设为和CPU核数相同

-XX:+UseAdaptiveSizePolicy
自动选择各区大小比例

CMS常用参数

-XX:+UseConcMarkSweepGC

-XX:ParallelCMSThreads
CMS线程数量

-XX:CMSInitiatingOccupancyFraction
使用多少比例的老年代后开始CMS收集,默认是68%(近似值),如果频繁发生SerialOld卡顿,应该调小,(频繁CMS回收)

-XX:+UseCMSCompactAtFullCollection
在FGC时进行压缩

-XX:CMSFullGCsBeforeCompaction
多少次FGC之后进行压缩

-XX:+CMSClassUnloadingEnabled

-XX:CMSInitiatingPermOccupancyFraction
达到什么比例时进行Perm回收

GCTimeRatio
设置GC时间占用程序运行时间的百分比

-XX:MaxGCPauseMillis
停顿时间,是一个建议时间,GC会尝试用各种手段达到这个时间,比如减小年轻代

G1常用参数

-XX:+UseG1GC

-XX:MaxGCPauseMillis
建议值,G1会尝试调整Young区的块数来达到这个值

-XX:GCPauseIntervalMillis
?GC的间隔时间

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wpdfgf.html