news 2026/6/10 13:28:18

61、【Ubuntu】【Gitlab】拉出内网 Web 服务:Gitlab 配置审视(五)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
61、【Ubuntu】【Gitlab】拉出内网 Web 服务:Gitlab 配置审视(五)

【声明】本博客所有内容均为个人业余时间创作,所述技术案例均来自公开开源项目(如Github,Apache基金会),不涉及任何企业机密或未公开技术,如有侵权请联系删除

背景

上篇 blog
【Ubuntu】【Gitlab】拉出内网 Web 服务:Gitlab 配置审视(四)
分析了external_url配置项在 Gitlab 中的作用,并开始分析 Gitlab 自带 Nginx 的server_name的作用,里面提到了 Host 字段的作用,下面继续分析

Nginx 配置审视

上篇 blog 提到了,Host 是 HTTP/1.1 协议中强制要求的请求头字段,用来告诉服务器,用户想访问的是机器上的哪个域名,使用浏览器访问 Web 服务,比如在发起HTTP/1.1请求时都会自动添加 Host 头,Host 值就是用户在地址栏输入的域名(或 IP + 端口),比如

  • http://www.example.com对应 Host 为www.example.com
  • https://api.myapp.com/v1/users对应 Host 为api.myapp.com
  • http://192.168.1.100:8080/test对应 Host 为192.168.1.100:8080

注意,如果 URL 中包含端口(不是默认的的80/443),Host 就会包含端口号,就像上面第三点一样,而默认端口号不会写到 Host 里(即使 URL 里显式写了,浏览器在构造 Host 头时,也会省略掉默认端口)

从上面举例可以看出来,Host 请求头的值,就是 URL 中://之后,到第一个/之前的部分,这部分内容包括域名(比如www.example.com),或 IP 地址(比如192.168.1.100),如果不是端口不是默认值(HTTP80,HTTPS443,之前 blog 【Ubuntu】【Gitlab】拉出内网 Web 服务:Gitlab 配置审视(三) 介绍过),还要带上显式端口号,比如上面的192.168.1.100:8080

这一点在官方文档HTTP/1.1规范 RFC 7230, Section 5.4 也能看到相关描述

可以看到,里面传达出几个关键信息:

  • 请求中的 Host 头字段,提供了目标 URI 中的主机名和端口信息(体现了用户想访问的网站名字,这个网站名字可以包含具体端口信息)
  • Host 头字段可以让 Web 服务器能够区分开不同的资源,比如同一台服务器上可能有成千上万个文件,页面和 API,但光靠路径,比如/index.html还远远不够,因为不同网站可能有同名路径,比如网站 A 有siteA.com/index.html,网站 B 有siteB.org/index.html,所以必须结合host/path,也就是 Host + 路径才能唯一确定用户想要什么,而这里的 Host,就是告诉服务器,这个index/html路径到底是哪个站点的
  • Host 作用尤其体现在一台 Web 服务器(同一个 IP 地址)上,同时为多个域名提供服务时,这就是虚拟主机的核心场景,如果两个域名都指向同一个 IP,请求都发到这台 Web 服务器,服务器就可以靠 Host 头区分开,该返回那个站点的内容,可以说,没有 Host,就无法实现一机多站的功能,这正是现代 Web 能以低成本运行海量网站的基础技术之一

OK,理解了 Host 头,再看访问请求和 Nginx 配置块中的server_name是怎么互动的


可以看到,server_name配置项和 Host 头就是匹配的,这意味着在写server_name时,和 Host 基本规则一样:

  • 首先,不需要也不应该默认端口,比如
server{listen *:80;server_name"example.com:80";# 有问题,不要写默认端口# 其他配置...}

这样就是错的,Nginx 不会匹配上example.com的域名,要把默认端口去掉

server{listen *:80;server_name"example.com";# 这样 OK# 其他配置...}
  • 另外,如果 Web 服务正在监听非标准端口(比如8080),并且用户通过http://example.com:8080进行访问,那么 Host 头是example.com:8080,这时可以用listen+server_name分离实现
server{listen *:8080;server_name"example.com";# 其他配置...}

最后再总结下,Host 字段为 URL 中://和第一个/之间,去掉协议默认端口后的内容,浏览器会自动设置 Host 字段,然后 Web 服务中 Nginx 会用这个 Host 字段去匹配server_name配置项,从而实现一台服务器托管多个网站的功能


OK,本篇先到这里,如有疑问,欢迎评论区留言讨论,祝各位功力大涨,技术更上一层楼!!!更多内容见下篇 blog

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 21:01:59

Florence-2-large-ft模型量化实战:从理论到部署的完整指南

Florence-2-large-ft模型量化实战:从理论到部署的完整指南 【免费下载链接】Florence-2-large-ft 项目地址: https://ai.gitcode.com/hf_mirrors/microsoft/Florence-2-large-ft 在当今AI应用快速发展的时代,模型推理效率已成为决定项目成败的关…

作者头像 李华
网站建设 2026/6/9 15:15:14

基于VUE的题库管理系统[VUE]-计算机毕业设计源码+LW文档

摘要:随着教育信息化的不断发展,题库管理系统在教育领域中发挥着日益重要的作用。本文旨在设计并实现一个基于VUE框架的题库管理系统,以提高题目管理的效率和准确性,为教学和考试提供有力支持。文章详细阐述了系统的需求分析、技术…

作者头像 李华
网站建设 2026/6/10 7:56:30

排序(包含插入,交换,快速,基数,桶排序)

排序确实要总结一下,因为下面写完就忘了上面的一些排序是什么了了,最好就是先写一个简单的描述,用来快速回顾。考研之前的知识点类似,进过三次变换之后排序变成什么样。请问符合什么排序。所以我们要知道这些排序的特点默认都是从…

作者头像 李华
网站建设 2026/6/10 8:59:41

软件行业全产业链全景深度研究报告

软件行业全产业链全景深度研究报告摘要:本报告围绕软件行业全产业链展开全景式研究,界定了软件行业全产业链的核心范畴与构成逻辑,系统剖析了上游基础支撑环节(硬件基础设施、基础软件、开源生态)、中游核心产品与服务…

作者头像 李华
网站建设 2026/6/10 8:54:50

普通专、本科学不了网络安全?最有效的自学方法我替你找到了

目录 前言自学网安第一阶段:打牢基础 学习这些基础知识有什么用呢? 第二阶段:化整为零 学习建议 第三阶段:实战演练 实践技巧 第四阶段:找准定位 深入学习建议:学习要避开的弯路 前言 “网络安全只有计…

作者头像 李华
网站建设 2026/6/10 8:56:39

Wi-Fi CERTIFIED Agile Multiband™ 技术概述

引言 Wi-Fi CERTIFIED Agile Multiband™是 Wi-Fi Alliance 的一项认证计划,其目的是使 Wi-Fi 网络资源能够得到更好的利用。Wi-Fi Agile Multiband™设备支持动态交换有关网络环境的信息,支持以智能化方式将客户端设备引导到推荐的接入点(AP)、频段或频道,还支持在同一 …

作者头像 李华