为什么升级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提供了更好的性能和稳定性,使其成为一个更加高效和可靠的网络通信框架。

你可能感兴趣的:(java,性能优化,数据库)