Netty4 中的内存管理

 

在Netty4中引入了新的内存管理机制极大地提高其性能,本文将对该内在管理机制进行剖析。java

 

这里有篇文章讲述了在推特(Twitter)内部 使用Netty的情况以及Netty4所带来的性能收益。并发

 

在分析Netty4的PooledByteBufAllocator以前,咱们最好先认识一下jemalloc。 Netty在4.0以前的版本已经尝试过经过优化内存管理的方式来提升性能(若是我没有记错的话),但4.0中的改进则特别 显著。在这个版本中,其内存管理实现主要是参考了jemalloc性能

 

jemalloc

 

jemalloc 是由Jason Evans在FreeBSD项目中引入的,其主旨是为了提高在并发环境下内存的分配效率。说白了就是替代 malloc。malloc之因此没有照顾到并发环境,那是因为在那个时代并发还只在理论,不曾普及。而如今则是多核的天下,连 手机都动则二、4核,甚至于8核了。与jemalloc齐名的还有Google的tcmalloc,其 实现与jemalloc多少也有点类似,这里不作介绍。优化

 

jemalloc的理念

 

咱们以买火车票为例,来简单地说明一下jemalloc与malloc的区别。原来的malloc,至关于只有一个售票窗口的售票大厅, 而jemalloc则在同一个售票大厅里面适量地增长的窗口。固然,火车票的总量(即内存大小)是不变的,买票的人至关于线程了。 提及来这也是很天然的事情的。google

 

在这里,一个售票窗口就是至关于一个Arena线程

 

Arena则按页(Page)来的管理内存,也就是说,一张车票就至关于一页。(后面就不太适合用火车票的例子了)。netty

 

同时,jemalloc还根据所请求的内存大小,对其进行分类。以下图:code

 

jemalloc allocation size category

 

默认状况下,Page的大小为4KB。如图,有三类,small、large和huge。small类的内存请求都属于一个内存页以内 (没有半张车票出售:()。另外,在small类里面,又分了三个子类,分别是Tiny、Quantum-Spaced和Sub-page。 这几个概念都在Netty中获得应用。blog

全文......内存

相关文章
相关标签/搜索