

新闻资讯
技术学院server_name 匹配客户端请求的 Host 头,按精确名→左通配符→右通配符→正则顺序优先级匹配,不依赖配置顺序;未匹配时交由 default_server 处理。
server_name 不是“绑定域名”,而是定义 Nginx 如何根据 Host 请求头选择虚拟主机。它只在 HTTP/1.1 协议下起作用,且必须与客户端实际发送的 Host 字段完全(或按规则)匹配,Nginx 才会把请求路由到该 server 块。
常见误解是以为配置了 server_name example.com 就能通过 IP 直接访问该站点——其实不会,除非你额外配了 default_server 或用 listen 80 default_server 显式指定兜底。
server_name api.example.com 只响应 Host: api.example.com
*:如 server_name *.example.com 匹配 foo.example.com,但不匹配 example.com 或 foo.bar.example.com
server_name ~^www\d+\.example\.com$,注意转义点号和美元符server_name "" 可匹配 Host 为空或缺失的请求(某些代理或旧客户端可能发这种)Nginx 对 server_name 的匹配不是“从上到下”,而是按**三类优先级分组比对**:精确名 → 左通配符(*.example.com)→ 右通配符(www.*)→ 正则(按配置文件中出现顺序)。同一组内才按书写顺序。
这意味着:
server_name example.com *.example.com www.example.com;和
server_name *.example.com example.com www.example.com;实际行为一致——
example.com 这个精确匹配永远胜过 *.example.com。
www.example.com 走特定配置,就单独写一行 server_name www.example.com
server_name 都不匹配,Nginx 会交给标记为 default_server 的那个 server 块处理典型现象是:浏览器输入 https://a.com 却打开 b.com 的页面,或者返回 404 —— 很可能是因为 server_name 写错、漏写,或没设 default_server 导致请求被第一个 server 块“误收”。
www 变体:server_name example.com www.example.com 比只写一个更稳妥listen 443 ssl 的 server 块里也配对应的 server_name,否则 SNI 后仍可能选错块curl -H "Host: wrong.com" http://your.ip 可模拟异常 Host 请求,验证匹配逻辑$host 和 $server_name 变量值,确认实际匹配到了哪个块开发时常用 *.test 或 localhost,但要注意系统 hosts 文件、DNS 解析和浏览器限制。
server_name ~^(?[^.]+)\.test$ 可捕获子域到变量 $subdomain,后续可用在 root 路径里,比如 root /var/www/$subdomain;
server_name _ 是“无效名称占位符”,常用于兜底 server,但它不匹配任何真实 Host,仅当无其他匹配且未设 default_server 时生效(不推荐依赖).localhost 和 .test
有特殊解析策略,但 Safari 和某些移动浏览器可能不认,建议开发环境统一用 127.0.0.1 xxx.test 并配好 hosts--add-host
server_name 表面简单,实际匹配逻辑藏在协议层和多 server 块协同里;最容易出问题的是 HTTPS + SNI 场景下两个 server 块的 server_name 和证书不一致,或者忘了给 default_server 配 SSL 参数。