nginx HTTP模块组成

原文链接:http://cjhust.blog.163.com/blog/static/17582715720124544047608/

1、数据结构

ngx_conf_s

struct ngx_conf_s {

    char                 *name; 

    ngx_array_t          *args;             //指令参数,从文件读入并放入这个数组

 

    ngx_cycle_t          *cycle;            //指向系统参数

    ngx_pool_t           *pool;              //内存池

    ngx_pool_t           *temp_pool;

    ngx_conf_file_t      *conf_file;      //配置文件信息 “./conf/main.conf”

    ngx_log_t            *log;                 //日志

 

    void                 *ctx;                    //(void ****)cycle->conf_ctx,装的是所有模块的配置信息

    ngx_uint_t            module_type;  //处理当前指令的模块的类型

    ngx_uint_t            cmd_type;       //处理这个指令的命令的类型

 

    ngx_conf_handler_pt   handler;     //指令处理函数

    char                 *handler_conf;     //这个是配合上面的handler使用

};

备注:该结构体主要用于读取配置时候,从配置文件和系统参数之间,ngx_conf_s起着桥梁的作用。

ngx_http_conf_ctx_t

typedef struct {

    void        **main_conf;

    void        **srv_conf;

    void        **loc_conf;

} ngx_http_conf_ctx_t;

备注:HTTP block中的配置结构主要分为3中,mainserver{}location{}

ngx_http_module_t

typedef struct {

    ngx_int_t   (*preconfiguration)(ngx_conf_t *cf);

    ngx_int_t   (*postconfiguration)(ngx_conf_t *cf);

 

    void       *(*create_main_conf)(ngx_conf_t *cf);

    char       *(*init_main_conf)(ngx_conf_t *cf, void *conf);

 

    void       *(*create_srv_conf)(ngx_conf_t *cf);

    char       *(*merge_srv_conf)(ngx_conf_t *cf, void *prev, void *conf);

 

    void       *(*create_loc_conf)(ngx_conf_t *cf);

    char       *(*merge_loc_conf)(ngx_conf_t *cf, void *prev, void *conf);

} ngx_http_module_t;

备注:HTTP模块中的ctx主要有上面8个函数组成。

ngx_command_s

struct ngx_command_s {

    ngx_str_t             name;

    ngx_uint_t            type;

    char               *(*set)(ngx_conf_t *cf, ngx_command_t *cmd, void *conf);

    ngx_uint_t            conf;

    ngx_uint_t            offset;

    void                 *post;

};

 

#define ngx_null_command  { ngx_null_string, 0, NULL, 0, 0, NULL }

2HTTP ctx

2.1 create_main_conf(ngx_conf_t *cf)

参数:ngx_conf_t *cf,配置结构体;

返回值:void *

备注:返回值可以作为ngx_http_conf_get_module_main_confgx_http _get_module_ main _conf的结果;

示例:

static void * ngx_http_barrier_create_conf(ngx_conf_t *cf)

{

  ngx_http_barrier_conf_t  *conf;   //自定义的一个结构

  conf = ngx_pcalloc(cf->pool, sizeof(ngx_http_barrier_conf_t));  //init by pcalloc

  if (conf == NULL) {

    return NULL;

  }

 

  conf->enable = NGX_CONF_UNSET;

  return conf;                                         //返回自定义的结构

}

2.2 create_srv_conf(ngx_conf_t *cf)

参数:ngx_conf_t *cf,配置结构体;

返回值:void *

备注:返回值可以作为ngx_http_conf_get_module_srv_confgx_http _get_module_ srv_conf的结果;

示例:

static void * ngx_http_barrier_create_conf(ngx_conf_t *cf)

{

  ngx_http_barrier_conf_t  *conf;   //自定义的一个结构

  conf = ngx_pcalloc(cf->pool, sizeof(ngx_http_barrier_conf_t));  //init by pcalloc

  if (conf == NULL) {

    return NULL;

  }

 

  conf->enable = NGX_CONF_UNSET;

  return conf;                                        //返回自定义的结构

}

2.3 create_loc_conf(ngx_conf_t *cf)

参数:ngx_conf_t *cf,配置结构体;

返回值:void *

备注:返回值可以作为ngx_http_conf_get_module_loc_confgx_http _get_module_loc_conf的结果;

示例:

static void * ngx_http_barrier_create_conf(ngx_conf_t *cf)

{

  ngx_http_barrier_conf_t  *conf;   //自定义的一个结构

  conf = ngx_pcalloc(cf->pool, sizeof(ngx_http_barrier_conf_t));  //init by pcalloc

  if (conf == NULL) {

    return NULL;

  }

 

  conf->enable = NGX_CONF_UNSET;

  return conf;                                        //返回自定义的结构

}

2.4 preconfiguration(ngx_conf_t *cf)

参数:ngx_conf_t *cf,配置结构体;

返回值:ngx_int_t

备注:返回值只是作为操作是否正确的一个判断;

示例:

static ngx_int_t

ngx_http_ssl_add_variables(ngx_conf_t *cf)

{

    ngx_http_variable_t  *var, *v;

 

    for (v = ngx_http_ssl_vars; v->name.len; v++) {

        var = ngx_http_add_variable(cf, &v->name, v->flags);

        if (var == NULL) {

            return NGX_ERROR;

        }

 

        var->get_handler = v->get_handler;

        var->data = v->data;

    }

 

    return NGX_OK;

}

2.5 init_main_conf(ngx_conf_t *cf, void *conf)

参数:ngx_conf_t *cfconfconfcreate_main时的返回值,在这里作为参数;

返回值:char *NGX_CONF_OK表示成功;

备注:返回值只是作为操作是否正确的一个判断;

示例:

static char *

ngx_http_core_init_main_conf(ngx_conf_t *cf, void *conf)

{

    ngx_http_core_main_conf_t *cmcf = conf;

//create_main时是未配置

if (cmcf->server_names_hash_max_size == NGX_CONF_UNSET_UINT) {

        cmcf->server_names_hash_max_size = 512;    //这里是init

    }

 

    if (cmcf->server_names_hash_bucket_size == NGX_CONF_UNSET_UINT) {

        cmcf->server_names_hash_bucket_size = ngx_cacheline_size;

    }

 

    cmcf->server_names_hash_bucket_size =

            ngx_align(cmcf->server_names_hash_bucket_size, ngx_cacheline_size);

 

 

    if (cmcf->variables_hash_max_size == NGX_CONF_UNSET_UINT) {

        cmcf->variables_hash_max_size = 512;

    }

 

    if (cmcf->variables_hash_bucket_size == NGX_CONF_UNSET_UINT) {

        cmcf->variables_hash_bucket_size = 64;

    }

 

    cmcf->variables_hash_bucket_size =

               ngx_align(cmcf->variables_hash_bucket_size, ngx_cacheline_size);

 

    if (cmcf->ncaptures) {

        cmcf->ncaptures = (cmcf->ncaptures + 1) * 3;

    }

 

    return NGX_CONF_OK;

}

2.6 merge_srv_conf(ngx_conf_t *cf, void *prev, void *conf)

参数:ngx_conf_t *cf,配置结构体,prevmain的配置结构体,confserver的配置结构体;prev=cf->ctx.srv_conf[ctx_index],conf=cf->servers.elts[s]->srv_conf[ctx_index]

返回值:char *,正确返回值是NGX_CONF_OK

备注:返回值只是作为操作是否正确的一个判断;

示例:

static char * ngx_http_barrier_merge_conf(ngx_conf_t *cf, void *parent, void *child)

{

  ngx_http_barrier_conf_t *prev = parent;

  ngx_http_barrier_conf_t *conf = child;

 

  if (conf->shm_zone == NULL){

     *conf = *prev;

  }

 

  ngx_conf_merge_value(conf->enable, prev->enable, 0);  //default is 0

  return NGX_CONF_OK;

}

备注:merge server的主要功能是,如果main里配置了enable=1,而server{}enable= NGX_CONF_UNSET,则将serverenable=mainenable=1

2.7 merge_loc_conf(ngx_conf_t *cf, void *prev, void *conf)

原理同merge_srv_conf(ngx_conf_t *cf, void *prev, void *conf)

2.8 postconfiguration(ngx_conf_t *cf)

参数:ngx_conf_t *cf

返回值:ngx_int_t,正确返回值是NGX_OK

备注:返回值只是作为操作是否正确的一个判断;

示例:

static ngx_int_t ngx_http_tracker_init(ngx_conf_t *cf)

{

  ngx_tracker_flag = 0;

  return NGX_OK;

}

备注:将全局变量flag清零,用于判断是否有barrier模块。如果不清零,将会导致如果配置中没有添加barrier zone,在kill –HUP时,由于全局变量flag值不变,即不为0 用户在执行traker指令时,出现段错误。

3HTTP commands

4、常用变量

#define NGX_HTTP_MAIN_CONF        0x02000000      //指令存放位置

#define NGX_HTTP_SRV_CONF         0x04000000

#define NGX_HTTP_LOC_CONF         0x08000000

#define NGX_HTTP_UPS_CONF         0x10000000

#define NGX_HTTP_SIF_CONF         0x20000000

#define NGX_HTTP_LIF_CONF         0x40000000

#define NGX_HTTP_LMT_CONF         0x80000000

 

#define NGX_HTTP_MAIN_CONF_OFFSET  offsetof(ngx_http_conf_ctx_t, main_conf)

#define NGX_HTTP_SRV_CONF_OFFSET   offsetof(ngx_http_conf_ctx_t, srv_conf)

#define NGX_HTTP_LOC_CONF_OFFSET   offsetof(ngx_http_conf_ctx_t, loc_conf)

 

示例:

static ngx_command_t  ngx_http_print_commands[] = {

{

ngx_string("print"),

      NGX_HTTP_LOC_CONF|NGX_CONF_TAKE1,    

      ngx_http_print_setup,       

      //set(),会转化读入指令传进来的参数,并将合适的值保存到配置结构体

      NGX_HTTP_LOC_CONF_OFFSET,

      offsetof(ngx_http_print_loc_conf_t, ed),

      NULL

},

 

      ngx_null_command

};

5、常用函数

5.1 处理Request

ngx_http_get_module_main_conf

函数功能:根据request请求和模块得到main配置。

#define ngx_http_get_module_main_conf(r, module)                             \

(r)->main_conf[module.ctx_index]

ngx_http_get_module_srv_conf

函数功能:根据request请求和模块得到server配置。

#define ngx_http_get_module_srv_conf(r, module)  (r)->srv_conf[module.ctx_index]

ngx_http_get_module_loc_conf

函数功能:根据request请求和模块得到location配置。

#define ngx_http_get_module_loc_conf(r, module)  (r)->loc_conf[module.ctx_index] 

5.2 解析conf

ngx_http_conf_get_module_main_conf

函数功能:根据conf结构和模块得到main配置。

#define ngx_http_conf_get_module_main_conf(cf, module)                        \

((ngx_http_conf_ctx_t *) cf->ctx)->main_conf[module.ctx_index]

ngx_http_conf_get_module_srv_conf

函数功能:根据conf结构和模块得到server配置。

#define ngx_http_conf_get_module_srv_conf(cf, module)                         \

((ngx_http_conf_ctx_t *) cf->ctx)->srv_conf[module.ctx_index]

ngx_http_conf_get_module_loc_conf

函数功能:根据conf结构和模块得到location配置。

#define ngx_http_conf_get_module_loc_conf(cf, module)                         \

 ((ngx_http_conf_ctx_t *) cf->ctx)->loc_conf[module.ctx_index]

5.3 Cycle

ngx_http_cycle_get_module_main_conf

#define ngx_http_cycle_get_module_main_conf(cycle, module)                    \

    (cycle->conf_ctx[ngx_http_module.index] ?                                 \

        ((ngx_http_conf_ctx_t *) cycle->conf_ctx[ngx_http_module.index])      \

            ->main_conf[module.ctx_index]:                                    \

        NULL)

 


你可能感兴趣的:(nginx HTTP模块组成)