Nginx 作为一个高性能的web 服务器,内存池的设计绝对是一个关键的原因,它大幅度提供了nginx的内存利用率。
内存池设计的原理就是内存块的一次性申请,一次性释放。避免的内存反复申请和释放,也能解决内存碎片的问题。最后,C 语言的指针虽然带来了极大的灵活性,但是也极容易带来内存泄露问题,从而程序猿们一个不小心就掉入无尽的深渊,内存池也能极大减少这种可能。
内存池的定义如下:
struct ngx_pool_s
{
ngx_pool_data_t d;
size_t max;
ngx_pool_t *current;
ngx_chain_t *chain;
ngx_pool_large_t *large;
ngx_pool_cleanup_t *cleanup;
ngx_log_t *log;
};
typedef struct ngx_pool_s ngx_pool_t;
nginx 提供一个内存池创建函数,用来创建一个内存池,就让他声明如下,内存池的大小,和日志。
ngx_pool_t* ngx_pool_create(size_t size, ngx_log_t *log);
一个内存池申请完成后的情况如下图,其中max指定了这块内存的代谢,d.last只想可用的的内存,ngx_pool_t这个数据结构本身,占据的改内存最前端,近水楼台。。。
nginx提供几个从内存池获取内存的函数,如下函数便是其中一个。
void * ngx_palloc(ngx_poot_t *pool, size_t size);
当然,随着内存池被使用的越来越多,d这个内存池的空间会越来越小,无法满足分配需求是,便为内存池重新申请一个ngx_pool_data_t,然后内存池的组织结构便变成如下图所示。
当然,内存池每次并不会每次都从第一个ngx_pool_data_t一直往下找,当一个ngx_pool_data_t分别内存失败次数超过4次后,内存池的current指针便往后移到下一个ngx_pool_data_t。
未完,待续。。。。。