缓存服务器介绍.doc

上传人:re****.1 文档编号:543738155 上传时间:2022-09-11 格式:DOC 页数:10 大小:201.02KB
返回 下载 相关 举报
缓存服务器介绍.doc_第1页
第1页 / 共10页
缓存服务器介绍.doc_第2页
第2页 / 共10页
缓存服务器介绍.doc_第3页
第3页 / 共10页
缓存服务器介绍.doc_第4页
第4页 / 共10页
缓存服务器介绍.doc_第5页
第5页 / 共10页
点击查看更多>>
资源描述

《缓存服务器介绍.doc》由会员分享,可在线阅读,更多相关《缓存服务器介绍.doc(10页珍藏版)》请在金锄头文库上搜索。

1、什么是缓存服务器无论企业有多大,Web缓存都有助于优化性能和节省带宽。而且如果选择了正确的缓存解决方案,它可以随着企业网络的增长而扩大,而无需进行昂贵且耗时的重建。Web缓存提供了比将访问对象放在Internet Web服务器上更好的方法,它将需要频繁访问的Web页面和对象保存在离用户更近的系统中。当再次访问这些对象的时候加快了速度。几年以前,理论是超高带宽的Internet连接会使Web缓存毫无用处,但是结果并非如此。即使最快的速率达到30-45Mbps的光纤Internet连接和速度在100 Mbps到1 Gbps速率的局域网相比仍然很慢,所以性能依旧是一个问题。除此之外,缓存提高了可用性

2、,因为即使托管的Web服务器停机或者由于网络问题而不可达时,缓存的对象拷贝仍然可以访问。如果企业根据流量付费,缓存还可以降低Internet连通性的费用。即使是小公司,缓存也会有利,而且好的缓存解决方案将随着企业级别升级。 1编辑本段缓存概念这是两种主要的Web缓存:直接缓存,将用户频繁访问的来自Internet服务器的Web对象的拷贝保存在企业本地网络中。反向缓存,企业内部Web服务器的Web对象的拷贝保存在企业网络边缘的代理服务器上以提高外界访问企业站点的性能。Web缓存可以根据不同等级进行配置:本地缓存:将Web对象缓存的拷贝保存在本地计算机中。大多数流行的Web浏览器默认情况下保留一个

3、先前访问对象的缓存。例如,Internet Explorer称之为“临时Internet文件”。本地缓存拷贝只是在用户频繁地从同一台机器访问页面时有用。代理缓存:代理服务器是为公司内的多个用户/客户计算机缓存Web对象的单独机器。它们是位于客户端和托管的Web服务器之间的计算机,而且它们比本地缓存效率更高,因为在企业本地网络中的任何用户或计算机访问某个Web对象时,缓存拷贝对想访问该对象的任何其他用户/计算机是可用的,无需到Internet服务器上再次下载它。代理缓存可以在网络边缘与防火墙结合使用。微软的ISA Server和BlueCoat的工具一样,既包括防火墙也包括缓存代理服务器。缓存服

4、务器也可以是单独的机器,运行免费的缓存软件或商业产品,例如:Linux版的Squid免费缓存代理MOWS基于Java分布式web和缓存服务器Vicomsoft RapidCache Server for Windows或MacintoshWinProxy for Windows可升级的缓存解决方案随着公司的扩大,单一的Web缓存服务器可能无法处理所有的通信或存储足够的Web对象。在这种情况下,可以扩展缓存解决方案以建立一个缓存阵列一组共同工作以便在组内分配缓存负载的缓存代理服务器。万一某个缓存服务器停机,还提供缺省的容量。要在阵列中操作,缓存服务器必须能够彼此使用协议进行通信,例如:WCCP(

5、Web缓存协调协议),Cisco缓存产品以及诸如Squid这样的开源代理使用。ICP(Internet缓存协议),被Squid和BlueCoat支持。CARP(缓存阵列路由协议),被ISA Server Enterprise Edition用来管理缓存服务器阵列的失效转移和负载平衡。CARP能够支持几乎无限的线性扩展以满足快速增长型企业的需求。当向某个阵列中添加或移除一台服务器时,CARP自动调整并再指定URL以有效地分布负载。缓存阵列能够以等级的或分布式的架构排列。在分布式缓存中,阵列中所有代理服务器处在一个“平等地位”而且负载在它们之间进行分配。在分等级的缓存中,代理以链式进行配置,它们处

6、在不同的等级,所以服务器或阵列连接到其它离Internet更近的服务器或阵列(离Internet最近的那些服务器或阵列被看作“上游的”,那些最远的被看作“下游的”)。这样,缓存内容会尽可能地靠近需要它的用户。阵列是高度可升级的,因为可以向阵列添加服务器,或向分等级的架构增加阵列等级,而无需扰乱目 前的缓存解决方案。另一个可扩展性问题是使用缓存减少分支机构网络带宽的能力。分支机构代理可能没有直接连接到Internet,但是可以使用拨号连接或办公室到办公室的WAN连接以便从总公司的上游代理服务器上请求Web对象。另一个选择是为需要向消费者提供基于Web的应用,可使用诸如由Akamai提供的服务。他

7、们的Web Application Accelerator服务通过下列方法优化性能:向他们的边缘服务器动态映射请求,并监视Internet路由以便在最快和最可靠的路由上传输。利用压缩技术和预取技术(pre-fetching)以最小化带宽使用率。用安全套接层(SSL)保护Web传输。根据企业指定的规则保存Web内容什么是Web缓存Web缓存是指一个Web资源(如html页面,图片,js,数据等)存在于Web服务器和客户端(浏览器)之间的副本。缓存会根据进来的请求保存输出内容的副本;当下一个请求来到的时候,如果是相同的URL,缓存会根据缓存机制决定是直接使用副本响应访问请求,还是向源服务器再次发送

8、请求。比较常见的就是浏览器会缓存访问过网站的网页,当再次访问这个URL地址的时候,如果网页没有更新,就不会再次下载网页,而是直接使用本地缓存的网页。只有当网站明确标识资源已经更新,浏览器才会再次下载网页。Web缓存的作用使用Web缓存的作用其实是非常显而易见的:减少网络带宽消耗:无论对于网站运营者或者用户,带宽都代表着金钱,过多的带宽消耗,只会便宜了网络运营商。当Web缓存副本被使用时,只会产生极小的网络流量,可以有效的降低运营成本。降低服务器压力:给网络资源设定有效期之后,用户可以重复使用本地的缓存,减少对源服务器的请求,间接降低服务器的压力。同时,搜索引擎的爬虫机器人也能根据过期机制降低爬

9、取的频率,也能有效降低服务器的压力。 减少网络延迟,加快页面打开速度:带宽对于个人网站运营者来说是十分重要,而对于大型的互联网公司来说,可能有时因为钱多而真的不在乎。那Web缓存还有作用吗?答案是肯定的,对于最终用户,缓存的使用能够明显加快页面打开速度,达到更好的体验。Web缓存的类型在Web应用领域,Web缓存大致可以分为以下几种类型:数据库数据缓存:Web应用,特别是SNS类型的应用,往往关系比较复杂,数据库表繁多,如果频繁进行数据库查询,很容易导致数据库不堪重荷。为了提供查询的性能,会将查询后的数据放到内存中进行缓存,下次查询时,直接从内存缓存直接返回,提供响应效率。比如常用的缓存方案有

10、memcached等。浏览器端缓存:浏览器缓存根据一套与服务器约定的规则进行工作,在同一个会话过程中会检查一次并确定缓存的副本足够新。如果你浏览过程中,比如前进或后退,访问到同一个图片,这些图片可以从浏览器缓存中调出而即时显现。服务器端缓存代理服务器缓存:代理服务器是浏览器和源服务器之间的中间服务器,浏览器先向这个中间服务器发起Web请求,经过处理后(比如权限验证,缓存匹配等),再将请求转发到源服务器。代理服务器缓存的运作原理跟浏览器的运作原理差不多,只是规模更大。可以把它理解为一个共享缓存,不只为一个用户服务,一般为大量用户提供服务,因此在减少相应时间和带宽使用方面很有效,同一个副本会被重用

11、多次。常见代理服务器缓存解决方案有Squid等,这里不再详述。CDN缓存:CDN(Content delivery networks)缓存,也叫网关缓存、反向代理缓存。CDN缓存一般是由网站管理员自己部署,为了让他们的网站更容易扩展并获得更好的性能。浏览器先向CDN网关发起Web请求,网关服务器后面对应着一台或多台负载均衡源服务器,会根据它们的负载请求,动态将请求转发到合适的源服务器上。虽然这种架构负载均衡源服务器之间的缓存没法共享,但却拥有更好的处扩展性。从浏览器角度来看,整个CDN就是一个源服务器,从这个层面来说,本文讨论浏览器和服务器之间的缓存机制,在这种架构下同样适用。Web应用层缓存

12、:应用层缓存指的是从代码层面上,通过代码逻辑和缓存策略,实现对数据,页面,图片等资源的缓存,可以根据实际情况选择将数据存在文件系统或者内存中,减少数据库查询或者读写瓶颈,提高响应效率。HTTP web缓存策略1. web缓存基本作用: HTTP协议中设计web缓存主要有以下几个作用:首先缓存能减少冗余数据的传输,可以减少网络成本; 其次缓存能减少客户端对远端server的依赖,从而提高了客户端装载页面的速度。下面着重阐述的是缓存的一些基本知识以及缓存策略给HTTP用户请求带来的改变。2. 缓存的基本知识:(1) 命中(hit)以及缺失(miss) 衡量缓存所带来的性能影响可以采用命中率和非命中

13、率两个参数。顾名思义,命中指的是缓存直接响应客户端的请求,缺失指的是缓存不能响应到客户端的请求,然后将请求转发给远端server。通俗地讲,前者是缓存直接将结果返回给server,而后者是缓存中不存在,客户端将直接从远端获取结果。(2)重验证(revalidation) 一般情况下,缓冲中的内容均存在一定的时效性,因此需要经常对缓存中的内容做有效性检查(fressness check),也叫“重验证”。触发对缓存中的内容进行重验证的方法很多,后面章节将会介绍到。 上图比较形象地描述了缓存命中、缺失以及重验证三种情形。值得注意的是,重验证并不表示缓存中的内容一定是过时的(stale),它仅仅表示

14、重验证触发条件收到,需要对缓存内容做重验证,仅此而已!(3)缓存的种类: 缓存一般可以分成个人缓存(或者私有缓存)和共享缓存(“共有缓存”两大类),比如在个人PC机上的缓存一般称为私有缓存,而对于门户网站,它们为了快速地响应各地用户请求,都会在CDN网络上建设自己的公共代理缓存(public proxy cache). 下面章节将主要讲解有关缓存的两个关键操作:更新和控制(指如何通过传递Header来控制缓存)缓存。3. 更新(keep copies fresh) 首先要明白的是更新操作主要是为了保证缓存中的内容与远端server中的内容保持一致,HTTP协议规范中规定了两种途径:定义文档过期

15、日期以及执行重验证。 文档过期时间(Document Expire)针对文档过期时间,HTTP协议中规定了两种方式:第一种是在远端server为所回复的每个文档附上”Expires:”HTTP头部;另外一种是为所回复的每个文档附上缓存控制头部”Cache-Control: max-age= ”. HeaderdescriptionCache-Control: max-ageThe max-age value defines the maximum age of the documentthe maximum legal elapsed time (in seconds) from when a document is first generated to when it can no longer be considered fresh enough to serveExpiresSpecifies an absolute expiration date. If the expiration date is in the past, the document is no longer fre

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 生活休闲 > 社会民生

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号