FULL GC隐患排查 优化

    最近其它业务线反馈统一的国际化方案容易导致FULL GC,先简单说一下国际化方案:实现了一个filter,过滤所有的http请求,将请求头信息所带的语言环境存储到session里面,然后重新实现了response,对于文案统一采用编码的防范,response输出的时候将编码根据语言环境进行替换。

    这里会有一个问题,如果是请求量比较大的应用,由于session的生命周期缘故,可能会导致FULL GC出现,为了排除这个隐患,首先对api的应用进行了排查,查看内存使用的情况,以及GC的情况 命令如下
1.sudo -u jetty jstat -gcutil pid
2.grep -n "CMC-initial-mark" gc.log.0.cuurnet


发现有部分session对象一直没有回收掉,进入了老年代,由于机器内存比较大,因此没有对应的报警,FULL GC时间也较短
但是需要进行优化 把request.getSesssion改下 或者我们应用工程自己设置下过期时间 现在默认是jetty容器的30分钟过期 15次ygc也回收不掉 15次ygc肯定不会超过30分钟 要进入老年代造成fullgc,具体方案如下:
1.去除getSession() 用setAttribute代替
2.session.setMaxInactiveInterval(5);

/**
 *
 * Specifies the time, in se
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值