您的位置:首页 > 理论基础 > 数据结构算法

Nginx学习笔记---Nginx模块的数据结构

2013-12-09 00:40 323 查看
typedef struct ngx_module_s     ngx_module_t;
struct ngx_module_s {
/*
* 下面的ctx_index、index、spare0、spare1、spare2、spare3、version变量不需要在定义时赋值,
* 可以用Nginx准备好的宏NGX_MODULE_V1来定义,它已经定义好了这7个值
*/
#define NGX_MODULE_V1   0,0,0,0,0,0,1

/*
* 对于一类模块(由下面的type成员决定类别)而言,ctx_index表示当前模块在这类模块中的序号。
* 这个成员常常是由管理这类模块的一个Nginx核心模块设置的,对于所有的HTTP模块而言,ctx_index
* 是由核心模块ngx_http_module设置的。ctx_index非常重要,Nginx的模块化设计非常依赖于各个模块
* 的顺序,它们既用于表达优先级,也用于表明每个模块的位置,借以帮助Nginx框架快速获得某个模块
* 的数据
*/
ngx_uint_t  ctx_index;

/*
* index表示当前模块在ngx_modules数组中的序号。注意,ctx_index表示的是当前模块在一类模块中的
* 序号,而index表示当前模块在所有模块中的序号,它同样关键。Nginx启动时会根据ngx_modules数组
* 设置各模块的index值。
*/
ngx_uint_t  index;

/* spare系列的保留变量,暂未使用 */
ngx_uint_t  spare0;
ngx_uint_t  spare1;
ngx_uint_t  spare2;
ngx_uint_t  spare3;

/* 模块的版本,便于将来的扩展。目前只有一种,默认为1 */
ngx_uint_t  version;

/*
* ctx用于指向一类模块的上下文结构体。因为Nginx模块有许多种类,不同类模块之间的功能差别很大。例如,
* 事件类型的模块主要处理I/O事件相关的功能,HTTP类型的模块主要处理HTTP应用层的功能。这样,每个模块
* 都有了自己的特性,而ctx将会指向特定类型模块的公共接口。例如,在HTTP模块中,ctx需要指向
* ngx_http_module_t结构体
*/
void    *ctx;

/* 用于处理nginx.conf中的配置项 */
ngx_command_t   *commands;

/*
* type表示该模块的类型,它与ctx指针是紧密相关的。在官方Nginx中,它的取值范围是以下5种:
* NGX_HTTP_MODULE、NGX_CORE_MODULE、NGX_CONF_MODULE、NGX_EVENT_MODULE、NGX_MAIL_MODULE
*/
ngx_uint_t  type;

/*
* 在Nginx的启动、停止过程中,以下7个函数指针表示有7个执行点会分别调用这7种方法。对于任何一个
* 方法而言,如果不需要Nginx在某个时刻执行它,那么简单地把它设为NULL空指针即可。
*/

/*
* 在master进程启动时回调init_master,但到目前为止,框架代码从来不会调用它,
* 因此,可将init_master设为NULL
*/
ngx_uint_t  (*init_master)(ngx_log_t *log);

/* 在初始化所有模块时被调用,在master/worker模式下,这个阶段将在启动worker子进程前完成 */
ngx_uint_t  (*init_module)(ngx_cycle_t *cycle);

/*
* 在正常服务前被调用,在master/worker模式下,多个worker子进程已经产生,在每个worker进程的
* 初始化过程会调用所有模块的init_process函数
*/
ngx_uint_t  (*init_process)(ngx_cycle_t *cycle);

/* 由于Nginx暂不支持多线程模式,所以init_thread在框架代码中还没有调用过,设为NULL */
ngx_uint_t  (*init_thread)(ngx_cycle_t *cycle);

/* exit_thread也不支持,设为NULL */
void    (*exit_thread)(ngx_cycle_t *cycle);

/* 在服务停止前调用。在master/worker模式下,worker进程会在退出前调用它 */
void    (*exit_process)(ngx_cycle_t *cycle);

/* 在master进程退出前被调用 */
void    (*exit_master)(ngx_cycle_t *cycle);

/*
* 以下8个spare_hook变量也是保留字段,目前没有使用,但可用Nginx提供的NGX_MODULE_V1_PADDING宏来填充
* #define NGX_MODULE_V1_PADDING 0,0,0,0,0,0,0,0
*/
uintptr_t   spare_hook0;
uintptr_t   spare_hook1;
uintptr_t   spare_hook2;
uintptr_t   spare_hook3;
uintptr_t   spare_hook4;
uintptr_t   spare_hook5;
uintptr_t   spare_hook6;
uintptr_t   spare_hook7;
};


未完待续......

本文出自 “人生理想在于坚持不懈” 博客,请务必保留此出处http://sofar.blog.51cto.com/353572/1338196
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: