登录
首页 >  文章 >  linux

Linux下Nginx多站点配置教程

时间:2026-04-26 11:01:18 179浏览 收藏

本文深入解析了Linux下Nginx如何通过单进程高效托管多个网站的核心机制——依托`server_name`指令与HTTP请求中的Host头精准匹配,而非依赖多进程;同时系统梳理了多站点配置中极易踩坑的关键点:各`server`块必须独立声明`root`和`location`以避免路径冲突,合理使用`default_server`实现兜底响应,借助SNI支持多域名HTTPS但需警惕老旧客户端兼容性,并强调配置验证(`nginx -t`)、热重载(`systemctl reload`)及实测调试(`curl -H "Host:..."`)的完整闭环,帮助运维者彻底摆脱“配置写了却不生效”的困扰。

Linux如何配置Nginx多站点共存_Linux Nginx多站点共存配置策略

一个Nginx进程怎么同时响应多个域名?

靠的是 server 块的 server_name 指令 + 主机头(Host)匹配,不是靠开多个进程。Nginx 启动后只跑一个 master 进程(加若干 worker),所有站点都注册在同一个配置文件或 include 的子配置里,靠请求里的 Host 字段决定走哪个 server 块。

常见错误是:两个 server 块监听同一端口(如 listen 80)但 server_name 写错(比如漏了 www、大小写混用、带空格),导致请求总落到默认 server(通常是第一个或 default_server 标记的那个)。

  • 确保每个 server 块都有明确且唯一的 server_name,例如:server_name example.com www.example.com;
  • 若想让某个站点当“兜底”,给它加上 default_serverlisten 80 default_server;
  • 别在 server_name 里写 IP 或端口,只写域名;通配符支持有限(*.example.com 可以,*.com 不行)

如何避免不同站点的 root 和 location 冲突?

每个 server 块必须独立定义 root,不能依赖上级或全局设置。如果漏写,Nginx 会回退到主配置里的 root(通常在 http 块),结果就是所有站点都指向同一个目录,内容互相覆盖。

location 块也一样:它只对当前 server 有效,但路径匹配规则容易重叠(比如一个写了 location /api,另一个写了 location /),Nginx 会按最长前缀匹配,不按书写顺序。

  • 每个 server 块开头就写清 root /var/www/example.com;
  • 静态资源路径尽量用绝对路径或基于 root 的相对路径,避免用 alias 除非真需要路径映射(alias 容易少斜杠出错)
  • 测试 location 匹配:用 curl -H "Host: example.com" http://127.0.0.1/test 绕过 DNS,确认进的是哪个 serverlocation

HTTPS 多站点要不要为每个域名配独立 SSL 证书?

不一定。现代 Nginx 支持 SNI(Server Name Indication),一个 IP + 443 端口可以托管多个 HTTPS 站点,只要每个 server 块有自己的 ssl_certificatessl_certificate_key

但注意:老系统(如 Windows XP + IE6)、部分嵌入式设备不支持 SNI,它们连上来会拿到第一个配置的证书,导致证书域名不匹配警告。如果必须兼容这类环境,就得用不同 IP 或不同端口(不推荐)。

  • Let’s Encrypt 的 certbot 支持单次申请多域名证书:certbot certonly -d example.com -d www.example.com -d blog.example.com
  • 不要复用同一组证书文件路径给多个 server 块——就算证书包含多个域名,也要确保每个 serverssl_certificate 指向正确的 PEM 文件
  • 记得 reload 而不是 restart:sudo nginx -t && sudo systemctl reload nginx,避免连接中断

为什么改完配置 reload 后新站点没生效?

最常见原因是 nginx -t 没报错,但实际没加载新配置——比如你把站点配置放到了 /etc/nginx/conf.d/mysite.conf,却忘了主配置里有 include /etc/nginx/conf.d/*.conf;,或者路径拼写错了(conf.d 写成 conf.d/ 少了最后斜杠不影响,但写成 conf.d/*.cfg 就不会加载)。

另一个隐蔽问题是:systemd 服务文件里可能禁用了 include,或用了自定义的 -c 参数指定配置路径,绕过了默认结构。

  • 运行 nginx -T | grep -A5 "server_name example.com" 查看 Nginx 实际加载的完整配置,确认你的 server 块确实在里面
  • 检查 ps aux | grep nginx 看 worker 进程启动时间,reload 后时间应更新;如果没变,说明 reload 失败或被忽略
  • 日志优先看 /var/log/nginx/error.log,而不是 access.log —— 配置加载失败通常只记 error 日志
Nginx 多站点真正难的不是写配置,而是验证请求确实进了预期的 server 块。建议每次新增站点后,用 curl -v -H "Host: yourdomain.com" http://localhost 直连本机,盯住响应头和返回内容,比反复刷浏览器靠谱得多。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Linux下Nginx多站点配置教程》文章吧,也可关注golang学习网公众号了解相关技术文章。

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>