Nginx基础数据结构分析-ngx_chain_t
nginx的filter模塊在處理從別的filter模塊或者是handler模塊傳遞過來的數(shù)據(jù)(實(shí)際上就是需要發(fā)送給客戶端的http response)。這個(gè)傳遞過來的數(shù)據(jù)是以一個(gè)鏈表的形式(ngx_chain_t)。而且數(shù)據(jù)可能被分多次傳遞過來。也就是多次調(diào)用filter的處理函數(shù),以不同的ngx_chain_t。
?
該結(jié)構(gòu)被定義在src/core/ngx_buf.h|c。下面我們來看一下ngx_chain_t的定義。
?
struct ngx_chain_s {
????ngx_buf_t????*buf;
????ngx_chain_t??*next;
};
?
就2個(gè)字段,next指向這個(gè)鏈表的下個(gè)節(jié)點(diǎn)。buf指向?qū)嶋H的數(shù)據(jù)。所以在這個(gè)鏈表上追加節(jié)點(diǎn)也是非常容易,只要把末尾元素的next指針指向新的節(jié)點(diǎn),把新節(jié)點(diǎn)的next賦值為NULL即可。
?
?
ngx_chain_t *ngx_alloc_chain_link(ngx_pool_t *pool);
?
該函數(shù)創(chuàng)建一個(gè)ngx_chain_t的對(duì)象,并返回指向?qū)ο蟮闹羔?#xff0c;失敗返回NULL。
?
#define ngx_free_chain(pool, cl)?????????????????????????????????????????????\
????cl->next = pool->chain;??????????????????????????????????????????????????\
pool->chain = cl
?
該宏釋放一個(gè)ngx_chain_t類型的對(duì)象。如果要釋放整個(gè)chain,則迭代此鏈表,對(duì)每個(gè)節(jié)點(diǎn)使用此宏即可。需要指出的是,對(duì)ngx_chaint_t類型的釋放,并不是真的釋放了內(nèi)存,而僅僅是把這個(gè)對(duì)象掛在了這個(gè)pool對(duì)象的一個(gè)叫做chain的字段對(duì)應(yīng)的chain上。以供下次從這個(gè)pool上分配ngx_chain_t類型對(duì)象的時(shí)候,快速的從這個(gè)pool->chain上取下鏈?zhǔn)自鼐头祷亓?/span>,當(dāng)然,如果這個(gè)鏈?zhǔn)强盏?#xff0c;才會(huì)真的在這個(gè)pool上使用ngx_palloc函數(shù)進(jìn)行分配。
總結(jié)
以上是生活随笔為你收集整理的Nginx基础数据结构分析-ngx_chain_t的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: NGINX-RTMP复杂度分析
- 下一篇: Nginx学习之三-ngx_http_r