网站首页 > 技术文章 正文
在 Nginx 中,default_server 是一个监听指令(listen directive)的参数,用于指定某个 server 块作为 默认的虚拟主机,处理所有未明确匹配 server_name 的请求(比如直接通过 IP 访问或未知域名)。
default_server的定义位置
default_server 是在 listen 指令中定义的,例如:
nginx
listen 443 ssl default_server; # IPv4
listen [::]:443 ssl default_server; # IPv6
- 这个配置告诉 Nginx:
- “如果请求的 Host 头不匹配任何 server_name,就由这个 server 块处理”。
- 如果没有 default_server,Nginx 会使用 第一个定义的 server 块 作为默认(不推荐依赖隐式行为)。
你的配置解析
nginx
server {
listen 443 ssl default_server; # 定义此块为 HTTPS 默认处理
listen [::]:443 ssl default_server; # IPv6 同理
server_name _; # 匹配任意未定义的域名
return 444; # 直接断开连接
ssl_certificate /path/to/dummy.crt; # 必须的证书(即使无用)
ssl_certificate_key /path/to/dummy.key;
}
- 作用:当用户直接访问 https://ip 时:
- 请求的 Host 头是 IP 地址,无法匹配其他 server 块的 server_name。
- 因此,Nginx 会使用这个 default_server 块处理,执行 return 444(强制关闭连接,不返回内容)。
关键注意事项
- 唯一性:
- 每个端口(如 443、80)只能有一个 default_server。如果重复定义,Nginx 会使用最后一个加载的配置。
- 检查是否有其他 server 块也定义了 default_server(冲突会导致意外行为)。
- SSL 证书必须存在:
- 即使 default_server 仅用于拒绝访问,HTTPS 也必须配置证书(可自签名)。
- 生成自签名证书:
- bash
- openssl req -x509 -nodes -days 365 -newkey rsa:2048 \ -keyout /etc/nginx/dummy.key \ -out /etc/nginx/dummy.crt \ -subj "/CN=localhost"
- 测试配置:
- 检查语法:sudo nginx -t
- 重载 Nginx:sudo systemctl reload nginx
- 测试访问:
- bash
- curl -I https://ip # 应返回无响应或错误 curl -I https://域名 # 应正常返回内容
如果仍然不生效
- 确保没有其他 server 块覆盖了 default_server。
- 检查 Nginx 是否加载了正确的配置文件(可能有多文件包含顺序问题)。
- 使用 nginx -T 查看完整配置,确认 default_server 是否正确绑定。
猜你喜欢
- 2025-09-09 使用Docker搭建一个Mail邮箱系统_docker搭建邮件服务器
- 2025-09-09 Linux必学技能 | 17个案例带运维小白快速精通Awk命令,拿来即用
- 2025-09-09 稳定的Claude Code渠道,白嫖100刀
- 2025-09-09 如何写出安全的、基本功能完善的Bash脚本
- 2025-09-09 代理 IP 地址与端口:核心概念、匹配逻辑及常见配置误区
- 2025-09-09 Linux重复操作太痛苦?Shell脚本让你1分钟搞定1小时活
- 2025-06-30 记录一次彻底清除挖矿病毒(挖矿 清退)
- 2025-06-30 linux计划任务管理(linux计划任务设置)
- 2025-06-30 Linux基本命令—修改命令别名(linux永久修改别名)
- 2025-06-30 CentOS nodejs环境配置(centos nodejs安装)
- 最近发表
-
- count(*)、count1(1)、count(主键)、count(字段) 哪个更快?
- 深入探索 Spring Boot3 中 MyBatis 的 association 标签用法
- js异步操作 Promise fetch API 带来的网络请求变革—仙盟创梦IDE
- HTTP状态码超详细说明_http 状态码有哪些
- 聊聊跨域的原理与解决方法_跨域解决方案及原理
- 告别懵圈!产品新人的接口文档轻松入门指南
- 在Javaweb中实现发送简单邮件_java web发布
- 优化必备基础:Oracle中常见的三种表连接方式
- Oracle常用工具使用 - AWR_oracle工具有哪些
- 搭载USB 3.1接口:msi 微星 发布 990FXA Gaming 游戏主板
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- js判断是否是json字符串 (75)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)