经过虚拟主机功能,实现单台物理服务器代理多个不一样web站点的功能。web
在HTTP通讯中,除客户端和服务器之外,还有一些用于通讯数据转发的应用程序,如代理、网关和隧道,它们配合服务器工做,将请求转发给通讯线路上的下一站服务器。后端
代理:一种有转发功能的应用程序,它扮演了位于服务器和客户端中间人的角色,接收由客户端发送的请求并转发给服务器,同时也接受服务器返回的响应并转发给客户端。浏览器
网关:转发其余服务器通讯数据的服务器,,接收从客户端发送来的请求,它就像本身拥有资源同样对请求进行处理,有时客户端可能都不会察觉,本身的通讯目标是个网关。缓存
隧道:在相隔甚远的客户端和服务器二者之间践行中转,并保持双发通讯链接的应用程序。安全
2.1 代理服务器
基本行为是接收客户端发送的请求后转发给其余服务器,代理不改变请求URL,会直接发送给前方持有目标服务器。拥有资源实体的服务器被称为源服务器,从源服务器返回的响通过代理服务器再传给后端。网络
每次经过代理服务齐全转发请求或响应时,会追加写入Via首部信息。网站
代理服务优点:利用缓存技术减小网络带宽流量;组织内部针对特定网站控制以获取访问日志为主要目的。加密
代理有多种使用方法,按两种基准分类,一种是否使用缓存,另外一种是是否会修改报文。spa
缓存代理
代理转发响应时,缓存代理会预先将资源的副本(缓存)保存在代理服务器上。
代理再次接收到对相同资源请求时,就能够不从源服务器那里获取资源,直接将缓存的资源做为响应。
透明代理
转发请求时,不对报文作任何加工的代理类型被称为透明代理,反之,对报文内容进行加工的代理称为非透明代理。
2.2. 网关
网关工做机制和代理十分类似,而网关能使通讯线路上的服务提供非HTTP协议服务。它能够提升通讯的安全性,保证客户端和网关之间的通讯线路上加密以确保链接的安全。
2.3隧道
按照要求创建起一条与其余服务器的通讯县里,届时使用ssl等加密手段进行通讯。隧道的目的是确保客户端能与服务器进行安全通讯。隧道自己不解析HTTP请求,请求保持原样中转给以后的服务器,隧道会在通讯双发断开链接时结束。
缓存是代理服务器或客户端本地磁盘内保存的资源副本,利用缓存可减小对源服务器的访问,所以也就节省了通讯流量和通讯时间。缓存服务器是代理服务器中的一种,并归类在缓存代理类型中,换句话说,当代理转发从服务器返回响应时,代理服务器将会保存一份资源副本。
缓存服务器的优点在于利用缓存可避免屡次从源服务器转发资源。
3.1 缓存有效期
当源服务器上的资源更新时,若是还使用缓存服务上这个资源的不变缓存时,就会出现返回更新前的旧资源;因此即便存在缓存,也会由于客户端的要求、缓存的有效期等因素,向源服务器确认资源的有效性,若判断缓存失败,缓存服务器就会再次从资源服务器上获取新资源。
3.2 客户端缓存
客户端缓存:主要是浏览器缓存,更新机制和服务器缓存服务器一致。