设为首页 收藏本站
查看: 639|回复: 0

[经验分享] Nginx学习笔记---Nginx模块的数据结构

[复制链接]

尚未签到

发表于 2018-11-13 11:22:16 | 显示全部楼层 |阅读模式
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;
  
};



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-634528-1-1.html 上篇帖子: linux编译安装LNMP:Linux+Nginx+MariaDB+PHP 下篇帖子: 搭建nginx服务器nginx-1.6.2.tar.gz
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表