nginx源码分析--配置信息的继承&合并

本文详细介绍了Nginx配置解析过程,重点在于http{}模块下配置的继承和合并机制。在ngx_http_block函数中,每个http模块的配置通过init_conf初始化,并通过ngx_http_merge_servers进行server{}配置的合并。每个server{}可以包含多个location{},配置信息逐级继承。当特定层级缺少某个命令时,会向上层查找并合并。merge_srv_conf和merge_loc_conf函数负责不同层次配置的合并,确保配置文件的灵活性。解析流程包括对http模块、server块和location块的递归遍历及配置继承。
摘要由CSDN通过智能技术生成

这里只讲述http{}模块下的配置:

       在ngx_http_block()函数内(这个函数别调用时在ngx_inti_cycle内的ngx_conf_parse函数,这个函数遇到http命令时 回调ngx_http_block,开启http{}配置块的解读工作),针对每一个http模块,调用init_conf之后,有调用了ngx_http_merge_servers()。这是为何!

      首先明确几点:一个http{}配置块内可以包含多个server{}配置块,每个server{}配置块可以包含多个location{}配置块,每个location{}配置块可以嵌套location{}配置块。把每个使用{}包含起来的配置块称为一个层次。在ngx_http_block中调用ngx_conf_parse时,还调用了ngx_http_core_server和ngx_http_core_location 这两个函数是解析server{}块和location{]块的。在不同的层次为同一个http模块创建了存储配置的结构体空间,比如在http{}层次为某一个http模块创建了 main_conf、srv_conf、loc_conf配置,在ngx_http_core_server内为同一个http模块创建了srv_conf loc_conf配置,在ngx_http_core_location函数内为同一个http模块创建了loc_conf配置。但是这是不同层次上的配置。对于某一个http模块中的某一个命令来说,它可能出现的区域有http{} server{} locaton{},如果在某一个server{}块内没有这个命令 那么它就需要从http{}中继承这个命令,如果某个server{}中存在这个命令,那么就不需要从http{}中继承;如果server{}中的某一个location{}中没有这个命令,那么就需要从上层(se

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值