为什么升级JDK 11后堆外内存使用增长了?

文章首发地址

JDK 11堆外使用增长的原因

JDK 11堆外使用增长的原因可能有以下几个:

  • G1垃圾回收器的默认设置更改: JDK 11中的G1垃圾回收器默认开启了堆外内存分配,以减少Full GC时的STW时间。因此,如果应用程序使用了G1垃圾回收器,那么堆外使用量就可能增加。
  • NIO使用的增加: 随着应用程序对网络的使用越来越多,NIO(New Input/Output)的使用也越来越广泛。NIO使用了堆外内存来提高IO操作的性能,因此如果应用程序使用了NIO,那么堆外使用量就可能增加。
  • 直接内存的使用增加: 直接内存是一种堆外内存,可以通过ByteBuffer.allocateDirect()方法来分配。在JDK 11中,Java NIO库中的一些类(如MappedByteBuffer、DirectByteBuffer等)使用了直接内存,因此应用程序中对这些类的使用增加,也可能导致堆外使用量增加。

需要注意的是,堆外使用量的增加并不一定是一件坏事,因为堆外内存相比Java堆内存来说,有更好的性能和可控性,可以用于处理一些需要高性能的任务。但是,如果堆外使用量增加过多,就可能导致操作系统的内存资源不足,从而影响应用程序的稳定性和性能。

JDK 11 堆外增长和Netty的关系

JDK 11堆外使用增长和Netty是有关联的。Netty是一个高性能的网络通信框架,它使用堆外内存来缓存数据,以提高网络通信的效率。随着JDK 11堆外使用增长,Netty的性能也得到了进一步提升。

在JDK 11之前,堆外内存的分配和回收是比较慢的,因此Netty需要使用一些技巧来尽可能地减少堆外内存的分配和回收。而JDK 11的堆外使用增长功能使得堆外内存的分配和回收更加高效和稳定,这使得Netty在JDK 11环境下的性能得到了提升。

此外,JDK 11引入了一个新的API:VarHandle,它可以更好地支持对堆外内存的访问和操作,这使得Netty在处理大型字节缓存的数据时变得更加高效。因此,JDK 11堆外使用增长为Netty提供了更好的性能和稳定性,使其成为一个更加高效和可靠的网络通信框架。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Walter Sun

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值