news 2026/5/23 21:11:18

ngx_http_find_virtual_server

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
ngx_http_find_virtual_server

1 定义

ngx_http_find_virtual_server 函数 定义在 ./nginx-1.24.0/src/http/ngx_http_request.c
staticngx_int_tngx_http_find_virtual_server(ngx_connection_t*c,ngx_http_virtual_names_t*virtual_names,ngx_str_t*host,ngx_http_request_t*r,ngx_http_core_srv_conf_t**cscfp){ngx_http_core_srv_conf_t*cscf;if(virtual_names==NULL){returnNGX_DECLINED;}cscf=ngx_hash_find_combined(&virtual_names->names,ngx_hash_key(host->data,host->len),host->data,host->len);if(cscf){*cscfp=cscf;returnNGX_OK;}#if(NGX_PCRE)if(host->len&&virtual_names->nregex){ngx_int_tn;ngx_uint_ti;ngx_http_server_name_t*sn;sn=virtual_names->regex;#if(NGX_HTTP_SSL&&defined SSL_CTRL_SET_TLSEXT_HOSTNAME)if(r==NULL){ngx_http_connection_t*hc;for(i=0;i<virtual_names->nregex;i++){n=ngx_regex_exec(sn[i].regex->regex,host,NULL,0);if(n==NGX_REGEX_NO_MATCHED){continue;}if(n>=0){hc=c->data;hc->ssl_servername_regex=sn[i].regex;*cscfp=sn[i].server;returnNGX_OK;}ngx_log_error(NGX_LOG_ALERT,c->log,0,ngx_regex_exec_n" failed: %i ""on \"%V\" using \"%V\"",n,host,&sn[i].regex->name);returnNGX_ERROR;}returnNGX_DECLINED;}#endif/* NGX_HTTP_SSL && defined SSL_CTRL_SET_TLSEXT_HOSTNAME */for(i=0;i<virtual_names->nregex;i++){n=ngx_http_regex_exec(r,sn[i].regex,host);if(n==NGX_DECLINED){continue;}if(n==NGX_OK){*cscfp=sn[i].server;returnNGX_OK;}returnNGX_ERROR;}}#endif/* NGX_PCRE */returnNGX_DECLINED;}
ngx_http_find_virtual_server 函数用于 根据 HTTP 请求的主机名(`Host` 头) 在监听端口的虚拟主机名集合中查找对应的 `server` 配置。 它优先进行精确及通配符哈希查找, 若失败则按顺序尝试正则匹配(支持 SSL SNI 阶段的特殊处理), 最终返回匹配到的虚拟服务器配置或未找到标志。

2 详解

1 函数签名

staticngx_int_tngx_http_find_virtual_server(ngx_connection_t*c,ngx_http_virtual_names_t*virtual_names,ngx_str_t*host,ngx_http_request_t*r,ngx_http_core_srv_conf_t**cscfp)
返回值 NGX_OK:成功找到匹配的虚拟服务器,*cscfp 已指向对应配置。 NGX_DECLINED:未找到任何匹配,调用者应使用默认服务器。 NGX_ERROR:匹配过程中发生严重错误,应中断当前连接。
参数1 ngx_connection_t *c 当前连接
参数2 ngx_http_virtual_names_t *virtual_names 指向 该地址端口下的虚拟主机名集合
参数3 ngx_str_t *host 表示待匹配的主机名
参数4 ngx_http_request_t *r 指向 当前 HTTP 请求结构体的指针,可以为 NULL
参数5 ngx_http_core_srv_conf_t **cscfp 指向服务器配置指针的指针(二级指针) 输出参数,当查找成功时, 将 *cscfp 设置为匹配到的 server 块配置。 查找失败时不修改。

2 逻辑流程

1 局部变量 2 空集合检查 3 hash 查找 4 查找成功 5 正则相关处理 6 未匹配

1 局部变量
{ngx_http_core_srv_conf_t*cscf;
cscf:类型为指向服务器核心配置的指针, 用于暂存哈希查找的结果,初始值未定义

2 空集合检查
if(virtual_names==NULL){returnNGX_DECLINED;}
空指针检查: 若传入的虚拟主机名集合为 NULL (通常意味着当前监听端口未配置任何 server_name), 则立即返回 NGX_DECLINED,表示未找到匹配, 调用者会使用默认服务器。 这避免了对空指针的非法访问。

3 hash 查找
cscf=ngx_hash_find_combined(&virtual_names->names,ngx_hash_key(host->data,host->len),host->data,host->len);
精确/通配哈希查找: 调用 ngx_hash_find_combined 在组合哈希表 virtual_names->names 中查找。 该哈希表同时存储了精确名称、前缀通配符(*.example.com)和后缀通配符(www.*)。 ngx_hash_key(host->data, host->len) 计算主机名字符串的哈希值(BKDR 哈希算法),用于定位桶。 后两个参数传递原始字符串和长度,用于在桶内逐字比对,防止哈希碰撞。 返回匹配到的 ngx_http_core_srv_conf_t 指针,若未找到则为 NULL。

4 查找成功
if(cscf){*cscfp=cscf;returnNGX_OK;}
检查哈希查找结果: 若 cscf 非空,说明成功匹配。 *cscfp = cscf: 将输出参数指向该服务器配置。 返回 NGX_OK,调用者即可使用 *cscfp 获得服务器配置。

5 正则相关处理
#if(NGX_PCRE)if(host->len&&virtual_names->nregex){ngx_int_tn;ngx_uint_ti;ngx_http_server_name_t*sn;sn=virtual_names->regex;#if(NGX_HTTP_SSL&&defined SSL_CTRL_SET_TLSEXT_HOSTNAME)if(r==NULL){ngx_http_connection_t*hc;for(i=0;i<virtual_names->nregex;i++){n=ngx_regex_exec(sn[i].regex->regex,host,NULL,0);if(n==NGX_REGEX_NO_MATCHED){continue;}if(n>=0){hc=c->data;hc->ssl_servername_regex=sn[i].regex;*cscfp=sn[i].server;returnNGX_OK;}ngx_log_error(NGX_LOG_ALERT,c->log,0,ngx_regex_exec_n" failed: %i ""on \"%V\" using \"%V\"",n,host,&sn[i].regex->name);returnNGX_ERROR;}returnNGX_DECLINED;}#endif/* NGX_HTTP_SSL && defined SSL_CTRL_SET_TLSEXT_HOSTNAME */for(i=0;i<virtual_names->nregex;i++){n=ngx_http_regex_exec(r,sn[i].regex,host);if(n==NGX_DECLINED){continue;}if(n==NGX_OK){*cscfp=sn[i].server;returnNGX_OK;}returnNGX_ERROR;}}#endif/* NGX_PCRE */

6 未匹配
returnNGX_DECLINED;}
最终未匹配: 如果哈希表和所有正则(如果有)都未找到, 返回 NGX_DECLINED。 调用者将使用监听端口的默认服务器。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/23 21:11:04

如何高效管理阅读APP书源:3个关键步骤构建稳定阅读体验

如何高效管理阅读APP书源&#xff1a;3个关键步骤构建稳定阅读体验 【免费下载链接】Yuedu &#x1f4da;「阅读」自用书源分享 项目地址: https://gitcode.com/gh_mirrors/yu/Yuedu 在数字阅读日益普及的今天&#xff0c;阅读APP已成为许多人的日常选择。然而&#xff…

作者头像 李华
网站建设 2026/5/23 21:10:06

分享一个Python爬虫的小技巧

最近在写爬虫的时候发现一个好用的方法&#xff0c;分享给大家。场景&#xff1a;需要爬取一个动态加载的网页&#xff0c;数据是通过AJAX请求获取的。传统做法是用Selenium模拟浏览器&#xff0c;但速度慢且不稳定。其实可以直接分析网络请求&#xff0c;找到API接口&#xff…

作者头像 李华
网站建设 2026/5/23 21:08:16

HsMod深度解析:基于BepInEx的炉石传说全方位模改进阶指南

HsMod深度解析&#xff1a;基于BepInEx的炉石传说全方位模改进阶指南 【免费下载链接】HsMod Hearthstone Modification Based on BepInEx 项目地址: https://gitcode.com/GitHub_Trending/hs/HsMod 你是否厌倦了炉石传说中繁琐的动画等待&#xff1f;是否渴望更高效的游…

作者头像 李华
网站建设 2026/5/23 21:08:15

GEO服务商技术评估的四维量化框架:以杭州文澜天下科技为例

评估维度如下。评估维度一&#xff1a;技术自研深度&#xff08;权重30%&#xff09;行业数据显示&#xff0c;当前市场上超千家宣称提供GEO服务的机构中&#xff0c;仅19%拥有完整的自主技术研发团队&#xff0c;超73%的品牌选错服务商&#xff0c;导致二次重构投入成本达到首…

作者头像 李华
网站建设 2026/5/23 21:07:15

python智慧乡村治理平台系统

目录同行可拿货,招校园代理 ,本人源头供货商项目背景核心功能技术架构应用场景预期效益项目技术支持获取博主联系方式 源码获取详细视频演示 &#xff1a;同行可合作点击我获取源码->获取博主联系方式->进我个人主页-->同行可拿货,招校园代理 ,本人源头供货商 项目背…

作者头像 李华