Java服务相关内存问题

一、堆内存

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

二、堆外存

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

三、年轻代

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

四、垃圾回收器

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值