一、堆内存
- 随意创建内存缓存,服务总体堆内存占用很难估量
- 内存缓存的维护,需要有删除机制,否则很容易导致内存溢出
- 内存缓存创建时,注意存的对象的大小,例如缓存大的数组或者大的字符串,很容易导致full gc或者永久代空间不足
二、堆外存
在缓存分层时,配置不合理,例如使用Ehcache时,堆内、堆外不合理
在服务启动时禁止system.gc,但是在代码中大量使用类似ByteBuffer.allocateDirect()的代码,直接在堆外存储中创建对象,导致缓存无法释放
三、年轻代
需要根据业务调整eden区、survivor区的大小比例
调整survivor区,对象老化的年龄代,默认15,也就是from space至to space复制拷贝的次数
调整eden区回收对象的算法
四、垃圾回收器
eden space、tenured space、permanent space的垃圾回收算法优化,需要掌握默认的垃圾回收器,掌握10中垃圾回收器的算法