Java服务相关内存问题

一、堆内存

  • 随意创建内存缓存,服务总体堆内存占用很难估量
  • 内存缓存的维护,需要有删除机制,否则很容易导致内存溢出
  • 内存缓存创建时,注意存的对象的大小,例如缓存大的数组或者大的字符串,很容易导致full gc或者永久代空间不足

二、堆外存

在缓存分层时,配置不合理,例如使用Ehcache时,堆内、堆外不合理
在服务启动时禁止system.gc,但是在代码中大量使用类似ByteBuffer.allocateDirect()的代码,直接在堆外存储中创建对象,导致缓存无法释放

三、年轻代

需要根据业务调整eden区、survivor区的大小比例
调整survivor区,对象老化的年龄代,默认15,也就是from space至to space复制拷贝的次数
调整eden区回收对象的算法

四、垃圾回收器

eden space、tenured space、permanent space的垃圾回收算法优化,需要掌握默认的垃圾回收器,掌握10中垃圾回收器的算法
 

猜你喜欢

转载自blog.csdn.net/u010313979/article/details/106988291