通过图轻松了解与HTTP协作的Web服务器
用单台虚拟主机实现多个域名,域名通过DNS服务映射到IP地址之后访问目标网站。
在相同的IP地址下,由于虚拟主机可以寄存多个不同主机名和域名的Web网站,因此在发送HTTP请求时,必须在Host首部内完整指定主体名或域名的URI。
通信数据转发程序:代理、网关、隧道。
代理
代理:有转发功能的应用程序,接收由客户端发送的请求并转发给服务器,同时也接收服务器返回的响应并转发给客户端。
代理不会改变请求URI,会直接发送给前方持有资源的目标服务器。
持有资源实体的服务器称为源服务器。每次通过代理服务器转发请求或响应时,会追加Via首部信息。
可以级联多台代理服务器,需要附加Via首部字段以标记经过的主机信息。
使用代理服务器的好处:利用缓存技术减少网络宽带的流量,组织内部支队网站的访问控制,以获取访问日志等等
代理按以下两种分类:
缓存代理:预先将资源缓存在代理服务器上,再次接受到相同请求,就可以直接返回而不从源服务器获取资源。
透明代理:转发请求或响应,不对报文进行任何处理的代理模式。反之对报文进行处理的代理模式称非透明代理。
例如:
缓存服务器是代理服务器的一种,归入缓存代理类型。
即使缓存,也可能因为客户端要求、缓存的有效期等因素,向源服务器确认资源的有效性,若判断缓存失效,缓存服务器会再次从源服务器上获取“新”资源
客户端浏览器也可以进行缓存,如果缓存有效,就可以直接从本地磁盘读取。和缓存服务器一样,判定缓存失效后,会再次请求。
网关
网关是转发其他服务器通信的服务器,就像自己拥有资源的源服务一样对请求进行处理。
网关的工作原理与代理很类似,但是网关能使通信路上的服务器提供非HTTP协议服务。
利用网关可以提高通信的安全性,因为可以在客户端与网关之间的通信线路上加密以确保连接安全。例如,网关可以连接数据库,使用SQL语句查询数据等等。
隧道
隧道是在相隔甚远的客户端和服务器两者间进行中转,保持双方通信连接的应用程序。届时使用SSL等加密手段进行通信。目的是确保客户端与服务器进行安全的通信。
隧道会在双方断开连接时结束。隧道本身透明,不用在意其存在。
本文参考自《图解HTTP》