第5章——与HTTP协作的Web服务器

第5章------与HTTP协作的Web服务器

用单台虚拟主机实现多个域名

​ 一台服务器可以使用虚拟主机功能拥有多个域名。

​ 域名通过DNS服务映射到IP地址(域名解析)之后访问目标网站。当请求发送到服务器时,已经是以IP地址形式访问了。

​ 相同的IP地址下,由于虚拟主机可以寄存多个不同主机名和域名的Web网站,因此在发送HTTP请求时,必须在Host首部内完整指定主机名或域名的URI。

## 通信数据转发程序:代理、网关、隧道

​ 代理------有转发功能的应用程序,客户端和服务端之间传信息。

网关------转发其他服务器通信数据的服务器,接收从客户端发送来的请求时,它就像自己拥有资源的源服务器一样 对请求进行处理。

隧道------在相隔甚远的客户端和服务器两者之间进行中转,并保持双方通信连接的应用程序。

代理

​ 代理不改变请求URI,转发功能。

​ 在HTTP通信过程中,可级联多台代理服务器。转发时,需要附加Via 首部字段以标记出经过的主机信息。

为什么用代理?

利用缓存技术(稍后讲解)减少网络带宽的流量;组织内部针对特定网站的访问控制;以获取访问日志为主要

目的,等等。

​ 代理分类:是否使用缓存,是否修改报文。

​ 缓存代理:预先将资源的副本(缓存)保存在代理服务器上。再次收到相同请求时直接响应返回。

透明代理:不对报文做任何加工的代理类型

网关

​ 使通信线路上的服务器提供非HTTP协议服务,能提高通信的安全性。

隧道

​ 使用SSL等加密手段进行通信,提高安全,本身不解析HTTP请求,在通信双方断开连接时结束。

保存资源的缓存

​ 缓存:代理服务器或客户端本地磁盘内保存的资源副本,可减少对源服务器的访问,节省通信流量和通信时间

​ 缓存有有效期限

​ 可以存在客户端浏览器中------称为临时网络文件

​ 和缓存服务器相同的,当判定缓存过期后,会向源服务器确认资源的有效性。若判断浏览器缓存失效,浏览器会再次请求资源

次请求资源

外链图片转存中...(img-5S0m18xO-1736243295833)

相关推荐
之恒君6 分钟前
React 性能优化(方向)
前端·react.js
3秒一个大19 分钟前
Vue 任务清单开发:数据驱动 vs 传统 DOM 操作
前端·javascript·vue.js
an869500119 分钟前
vue自定义组件this.$emit(“refresh“);
前端·javascript·vue.js
Avicli20 分钟前
Gemini3 生成的基于手势控制3D粒子圣诞树
前端·javascript·3d
GinoWi20 分钟前
HTML标签 - 列表标签
前端
o__A_A21 分钟前
渲染可配置报告模板+自适应宽度(vue3)
前端·vue.js
鹏北海21 分钟前
Vue 组件解耦实践:用回调函数模式替代枚举类型传递
前端·vue.js
JienDa23 分钟前
JienDa聊PHP:从Laravel到ThinkPHP的现代Web开发实践
前端·php·laravel
软件技术NINI26 分钟前
盒模型在实际项目中有哪些应用场景?
前端·css·html
Beginner x_u27 分钟前
从组件点击事件到业务统一入口:一次前端操作链的完整解耦实践
前端·javascript·vue·业务封装