CDN中前端层的复制
前端层的复制是为了提高静态内容分发的性能和可扩展性。将静态内容的分发转由边缘服务器来完成是为了解决可扩展性的问题,因为这样做可以避免出现在对等点和广域网链路处的网络拥堵风险,而这两个地方的拥堵是网络延时的主要原因。
通过使用一个第三方的网络设施来加速静态内容的分发是一种提高内容分发网络边缘性能的常用方法。不过静态内容的分发仍然是一个棘手的工作,因为富媒体(rich-media)内容的使用已经变得越来越多,它产生的流量正在成为互联网流量的一个重要组成部分。将这类媒体内容的分发转移到接近客户端的地方,可以获得很大的好处,原因有二:首先由于这类内容的尺寸庞大,在对等点处的网络延时会使用户明显感觉到性能的下降;其次借助常用的HTTP流技术可以降低分发时间上的不确定性,使媒体的播放变得更加流畅。
由于多媒体内容的尺寸较大,所以通常只把每个多媒体内容中用户最感兴趣的部分(而不是全部)缓存在边缘服务器中,称分段缓存(segment caching)。一个多媒体资源中每个片段(fragment)的受欢迎度由用户的访问模式决定:如果用户采用(从头)连续访问的模式,那么通常使用连续缓存的方法,也就是存储资源的起始部分,以减小缓冲时间;如果用户的访问模式主要是媒体中的随机定位,那么就要使用不同的缓存技术,如交错缓存方法,这样可能会更加有效。
当待分发的Web内容是由片段(fragment)组装而成时,有人提出了将流内容分割为段(segment)的方法。这个方法要求边缘服务器做更多的工作,其前端层必须包含两个功能:为每个片段提供单独的缓存和片段的组装。作为一个独立的信息实体,每个片段可以包含描述其缓存能力的配置信息,该信息用来指示片段能否被缓存和它在网络上的存活时间(Time-To-Live,TTL),这就可以在片段(而不是在网页)的粒度上管理内容的新鲜度和生命周期。
当一个用户请求网页时,边缘服务器在它的缓存中找到该网页的片段,然后立刻将其组装起来。只有那些失去时效或没有被缓存的片段才从源服务器取。因此在边缘服务器上使用基于片段的缓存和动态组装方法对源服务器而言有两个好处:一是它不必完成组装页面的任务;二是它一般只需要分发页面的一小部分内容,也就是边缘服务器上那些失效或缓存中没有的片段。对于大部分由动态创建的网页构成的网络资源,基于片段的缓存技术可以在距离终端用户最近的边缘网络向用户提供这些内容,从用户对性能的感受可以发现这一技术已被证明能够有效地改善响应时间。不仅如此这一技术同样对边缘服务器有益:那些被不同网页共享的同个片段只需保存一份副本,这就大大提高了磁盘空间的利用率;同时它也能够降低边缘服务器上缓存的失效频度,因为网页中的不同部分只有在过期的时候才标记为“失效”。
衡量基于片段的缓存技术的常用标准是ESI(一种基于XML的标记语言),能够使用XML来区分内容是否应该缓存。内容提供商根据其开发环境制订相应的ESI规范,用来设计和开发业务逻辑以实现网页的产生和装配。除了将页面分解为片段这一基本功能(即使在一个有条件的方式下),ESI的功能还包括片段不可用时的异常处理以及对被缓存片段的失效性做出判断,所以ESI可以提供比TTL机制更强的一致性确保机制。
大多数支持基于片段的缓存技术的边缘服务器并不提供缓存之间的任何协作,也就是说这些缓存完全被作为独立的实体。这就使我们无法享受协作带来的好处,而采取协作的方式可以使边缘服务器发挥其潜在的缓存能力。基于片段的方法也面临与动态内容的类型相关的应用性问题以及网页的片段分解问题,而该方法的主要缺点都与这些问题有关。如果用户的请求序列具有高度的局部性同时源服务器上的内容更新不频繁,基于片段的缓存就能有效地应用。这个条件保证了片段的可缓存性参数足以用来管理内容的新鲜度,从而减轻了源服务器给缓存中的片段设置“失效”标志的负担。因为缓存、划分片段、组装片段等工作都是在每一个具体应用上进行,所以该技术很缺乏透明性。由于ESI代码必须加到原始代码上,这就需要完全修改网页的代码,因此ESI的性能就取决于网页的结构。对于同时为多个内容提供商分发内容的边缘服务器来说,上述对片段的人工辨识和标记几乎是无法承受的。
网防cdn专业提供国内外高防cdn加速服务
本文链接:http://www.f8i.com/news/349.html
CDN中前端层的复制的更多相关文章
- Java中Action层、Service层、Modle层和Dao层的功能区分
一.Java中Action层.Service层.Modle层和Dao层的功能区分: 首先,这是现在最基本的分层方式,结合了SSH架构. modle层就是对应的数据库表的实体类.(即domain) Da ...
- 负载均衡技术在CDN中发挥着重要作用
转载地址:http://www.qicaispace.com/gonggao/server/page01/info07.asp CDN是一个经策略性部署的整体系统,能够帮助用户解决分布式存储.负载均衡 ...
- java中Action层、Service层和Dao层的功能区分
Action/Service/DAO简介: Action是管理业务(Service)调度和管理跳转的. Service是管理具体的功能的. Action只负责管理,而Service负责实施. DAO只 ...
- TCP/IP中链路层的附加数据(Trailer数据)和作用
1.TCP/IP中链路层的附加数据是什么 在用wireshark打开报文时,链路层显示的Trailer数据就是附加数据,如图 2.如何产生 1.例如以太网自动对小于64字节大小的报文进行填充(未实验) ...
- 网站建设中前端常用的jQuery+easing缓动的动画
网站建设中前端人员利用jQuery实现动画再简单不过了,只是要实现更酷的效果还需要插件来帮忙,easing就是一款帮助jQuery实现缓动动画的插件,经过试用,效果很不错! 下载该插件:jquery. ...
- 【Protle99SE】PCB中各层的含义【小汇】
忽然发现,对solder和paste,layer和plane这两对有些糊涂了,摘录网络中的文章如下: [http://www.360doc.com/content/10/0608/15/514342_ ...
- 解决vim中鼠标右键无法复制的问题
转:http://www.cnblogs.com/jianyungsun/archive/2011/03/19/1988855.html 这是我的vim配置文件:jeffy-vim-v2.4.tar ...
- MVC5中Model层开发数据注解
ASP.NET MVC5中Model层开发,使用的数据注解有三个作用: 数据映射(把Model层的类用EntityFramework映射成对应的表) 数据验证(在服务器端和客户端验证数据的有效性) 数 ...
- SQL中两种表复制语句
Insert是T-sql中常用语句,Insert INTO table(field1,field2,...) values(value1,value2,...)这种形式的在应用程序开发中必不可少.但我 ...
随机推荐
- centos 如何关闭防火墙?
1 查看防火墙状态: 命令: /etc/init.d/iptables status 如果是开着显示内容类是截图 2 临时关闭防火墙: 命令:/etc/init.d/iptables stop ...
- 申请9位数QQ
官网:QQ注册第一步:下面手机号不要填写 第二步:验证 第三步:开始填写手机号 注:不行就多试着几次就可以了,是不是很惊喜啊!(漏洞,被腾讯发现就不行了喽)
- re模块与正则表达式
一.正则表达式概念 正则表达式,又称正规表示式.正规表示法.正规表达式.规则表达式.常规表示法(英语:Regular Expression,在代码中常简写为regex.regexp或RE),是计算机科 ...
- crontab 定时任务守护程序,停止服务器时出现 job for * canceled
(1)首先要在程序启动的时候加入定时任务到crontab #! /bin/shmkdir -p /home/apps/components/ams/ 2>/dev/nullcp ./amswat ...
- Chrome中xpath表达式巧妙获取
对于xpath语法不熟悉,或者要快速匹配出xpath的小伙伴来说这种方式是最快捷的了. 步骤如下: 1.打开chrome 2.ctrl + shift + c 个人比较喜欢用快捷键,不喜欢用快捷键的就 ...
- 如何设置select和option的文字居中?
今天在设置option文字居中时发现,给select设置text-align:center在火狐浏览器下ok,但是在chrome浏览器无效,然后option在两个浏览器下设置text-align:ce ...
- 单元测试系列:JUnit单元测试规范
更多原创测试技术文章同步更新到微信公众号 :三国测,敬请扫码关注个人的微信号,感谢! 原文链接:http://www.cnblogs.com/zishi/p/6762032.html Junit测试代 ...
- console引起的eclipse 僵死/假死 问题排查及解决[转]
原文链接:http://www.iteye.com/topic/1133941 症状: 使用Eclipse win 64位版本,indigo及kepler都重现了,使用tomcat 6.0.39,jd ...
- tomcat集群与负载均衡
参考文章http://kalogen.iteye.com/blog/784908,加上了自己调试过程中遇到的问题. 注1:实现此集群的方法参考了网上的很多文章,但由于很多文章都表明是原创的,故无法知道 ...
- JMS基础篇
首先我们需要下载 ActiveMQ:http://activemq.apache.org/. 启动 ActiveMQ 服务:解包下载的 ActiveMQ >进去其bin 目录>双击 act ...