HTTP学习笔记:网关、代理、隧道、缓存
来源:互联网 发布:如何评价无间道 知乎 编辑:程序博客网 时间:2024/06/04 18:29
HTTP通信时,除客户端和服务器以外,还有一些用于通信数据转发的应用程序,如代理、网关和隧道。他们可以配合服务器工作。
这些应用程序和服务器可以将请求转发给通信线路上的下一站服务器,并且能接受从那台服务器发送的响应再转发给客户端。
代理
代理是一种带有转发功能的应用程序,它扮演了位于服务器和客户端中间人的角色,接受由客户端发送的请求并转发给服务器,同时也接收服务器返回的响应并转发给客户端。
代理不改变请求URI,会直接发送给前方持有资源的目标服务器。
在HTTP通信过程中,可以级联多台代理服务器。
使用代理服务器的理由有:
- 利用缓存技术减少网络带宽的流量
- 组织内部针对特定网站的访问控制
- 以获取访问日志为主要目的
- ……
按是否使用缓存、是否修改报文,可以把代理进行分类:
缓存代理:
代理转发响应时,缓存代理会预先将资源的副本保存在代理服务器上。
当代理再次接受到对相同资源的请求时,就可以不从源服务器那里获取资源,而是将之前缓存的资源作为响应返回。透明代理
转发请求或者响应时,不对报文作任何加工。
网关
网关是转发其他服务器通信数据的服务器。网关可以使通信线路上的服务器提供非HTTP协议服务。
接受从客户端发送来的请求时,它就像自己是拥有资源的源服务器一样对请求进行处理。有时客户端可能都不会察觉自己的通信目标是一个网关。
利用网管可以提高通信的安全性。
隧道
隧道是在相隔甚远的客户端和服务器两者之间进行中转,并保持双方通信的应用程序。
隧道本身不回去解析HTTP请求,保持原样中转。
保存资源的缓存
缓存是指代理服务器或者客户端本地磁盘内保存的资源副本。
利用缓存可以减少对源服务器的访问,因此也就节省了通信流量和通信时间。
缓存服务器是代理服务器的一种,当代理转发从服务器返回的响应时会保存一份资源的副本。
缓存服务器的优势在于利用缓存可避免多次从源服务器转发资源,客户端可就近从缓存服务器上获取资源,而源服务器也不必多次处理相同的请求了。
缓存的有效期限
即使缓存服务器内有缓存,也不能保证每次都会返回对同资源的请求,因为关系到缓存资源的有效性问题。
即使存在缓存,也会因为客户端的要求、缓存的有效期等因素,向源服务器确认资源的有效性。若缓存判断失效,缓存服务器将会再次从源服务器上获取新资源。
客户端的缓存
缓存不仅可以存在于缓存服务器内,也可以存在客户端浏览器中。
浏览器缓存如果有效,就不必再向服务器请求相同的资源了,可以直接从本地磁盘内读取。
另外,和缓存服务器相同的一点是,当判定缓存过期后,会向源服务器确认资源的有效性。若判定浏览器缓存失效,浏览器会再次请求资源。
- HTTP学习笔记:网关、代理、隧道、缓存
- 图解HTTP笔记之第五章:代理、网关,隧道
- 网关,隧道,代理
- 代理、网关、隧道
- 代理、网关、隧道、中继
- 代理、网关、隧道
- HTTP——网关、隧道、中继、Agent代理
- 《HTTP权威指南》学习笔记(8)第8章 集成点:网关、隧道及中继(关键词:计算机网络/HTTP/网关/隧道/中继)
- HTTP学习(三)-网关、隧道、web机器人、cookie
- http之网关、隧道、代理服务器
- 通信数据转发程序:代理、网关、隧道
- HTTP代理原理以及HTTP隧道技术
- HTTP代理原理以及HTTP隧道技术
- HTTP代理原理以及HTTP隧道技术
- HTTP代理原理以及HTTP隧道技术
- 反弹端口 HTTP代理 HTTP隧道技术
- HTTP代理原理以及HTTP隧道技术
- 5.1通信数据转发程序:代理,网关,隧道
- VS2015监视变量及栈调用情况
- Codeforces 353D Queue【思维】好题~
- Ubuntu新手-挂载与mount
- Cmake入门实战
- SpringMVC使用Redis集群
- HTTP学习笔记:网关、代理、隧道、缓存
- BigInteger类
- 系统调用与库函数的区别
- mac写ntfs格式的移动硬盘
- BZOJ 2588 Count on a tree 可持久化线段树+LCA
- 简洁精美源于分析透彻,构思明确、求精,逻辑练达。(5)
- LeetCode
- JNI基础(六)C调java代码
- BigDecimal类