CDN(Content Delivery Network 内容分发网络服务 )服务简介

CDN的全称是Content Delivery Network,即内容分发网络。其基本思路是尽可能避开互联网上有可能影响数据传输速度和稳定性的瓶颈和环节,使内容传输的更快、更稳定。通过在网络各处放置节点服务器所构成的在现有的互联网基础之上的一层智能虚拟网络,CDN系统能够实时地根据网络流量和各节点的连接、负载状况以及到用户的距离和响应时间等综合信息将用户的请求重新导向离用户最近的服务节点上。其目的是使用户可就近取得所需内容,解决 Internet网络拥挤的状况,提高用户访问网站的响应速度。

服务模式

内容分发网络(CDN)是一种新型网络构建方式,它是为能在传统的IP网发布宽带丰富媒体而特别优化的网络覆盖层;而从广义的角度,CDN代表了一种基于质量与秩序的 网络服务模式。
简单地说,内容分发网络(CDN)是一个经策略性部署的整体系统,包括 分布式存储负载均衡、网络请求的重定向和内容管理4个要件,而内容管理和全局的网络流量管理(Traffic Management)是CDN的核心所在。通过用户就近性和 服务器负载的判断,CDN确保内容以一种极为高效的方式为用户的请求提供服务。
总的来说,内容服务基于 缓存服务器,也称作 代理缓存(Surrogate),它位于网络的边缘,距用户仅有"一跳"(Single Hop)之遥。同时, 代理缓存是内容提供商源 服务器(通常位于CDN 服务提供商的数据中心)的一个透明 镜像。这样的架构使得CDN 服务提供商能够代表他们客户,即内容供应商,向最终用户提供尽可能好的体验,而这些用户是不能容忍 请求响应时间有任何延迟的。

CDN通俗解释

CDN的通俗理解就是网站加速,可以解决跨运营商,跨地区,服务器负载能力过低,带宽过少等带来的网站打开速度慢等问题。
比如:
1.一个企业的网站服务器在北京,运营商是电信,在广东的联通用户访问企业网站时,因为跨地区,跨运营商的原因,网站打开速度就会比北京当地的电信客户访问速度慢很多,很容易造成这个企业的客户流失
2.一个网站的服务器性能比较差,承载能力有限,有时面临突发流量,招架不住,直接导致服务器崩溃,网站打不开,尤其是电商网站在节日期间,因为这种情况网站打不开,销售额白白流失的占比都高涨至60%
3.再比如一些中小企业租用的虚拟主机,因为跟好几个网站共用一台服务器,每个网站所分带宽有限,带宽过小经常导致流量稍微一多,网站打开速度就很忙,甚至打不开
以上只是几个简单举例,都可以通过CDN来解决,大家可以参考下。
使用CDN的好处?
1. 不用担心自己网站访客,在任何时间,任何地点,任何网络运营商,都能快速打开网站。
2. 各种服务器虚拟主机带宽等采购成本,包括后期运维成本都会大大减少。
3. 给网站直接带来的好处就是:流量,咨询量,客户量,成单量,都会得到大幅度提升。
CDN的价格?
大家提起CDN,都会望而却步,因为CDN太贵,都是大企业才能用得起的贵族式服务,而如今面对中小企业的CDN技术开发已经实现,并进入市场开始运营,尤其是CDN行业龙头老大上市企业—蓝汛,率先发起了中小企业的CDN技术开发,为中小企业CDN量身定制了 Webluker产品,成为中小企业解决网站打开速度慢的福音,而且考虑到中小企业的经济承受能力, Webluker定价计费合理,在业界被众多中小企业誉名为“最专业的服务,最低的价格。”
现在市面上CDN提供商计费方式多样,有按每月最低消费的,有按带宽收费的,有按请求数收费的,有包月包季包年限制的,还有些大多人看不懂的技术指标收费的,总之比较复杂,CDN服务在所有计费方式中,中小企业一至认为按流量收费最为合理,另外大多按流量计费方式中会有时间限制,规定时间内用不完就会全部作废,对于流量把握不好的中小企业,存在相当一部分浪费,但是,蓝汛旗下的 Webluker,已经应广大客户的要求实现了“不但按流量收费,而且不限时,售后服务及时”,使中小企业做到完全无后顾之忧的使用CDN网站加速。可能就是因为这些,中小企业才会对 Webluker誉为“最专业的服务,最合理的价格”的美名。
CDN选择的标准?
因为CDN技术牵涉到技术研发,以及售后问题解决的是否快捷,所以在选择cdn服务商时,一定选择技术研发实力强专业的公司,以保证在售后出现问题时能得到及时的解决,而不能仅仅图便宜,当时是便宜了,可事后会用更大的金钱代价来弥补,所以请选择CDN服务的企业网站,一定要慎重了,尤其是咱中小企业,更经不起折腾。由于cdn市场很混乱,付完钱,出问题售后跟不上的案例太多了,大家在选择时还是选择专业的CDN服务商为上策,不要只图便宜,对于专业的CDN提供商已经很便宜了。
在CDN业界国内可供中小企业选择的CDN专业提供商有: Webluker,盛大云,叁加伍,加速乐等,大家可以在网上搜搜,到他们官网看看,按照上面的标准进行选择,应该没什么问题。

推送式与拉取式CDN服务的优劣问题

因为以前也做过一些站,所以用过国内外的一些cdn加速服务。我发现这些服务无非分为两种

  1. 以Amazon的CloudFront为代表,内容发布者主动将需要发布的资源推送到CDN发布服务器上,然后由CDN服务商分发到其各节点。国内的提供商有UpYun
  2. CloudFlare为代表,与前者不同,内容不需要主动发布,而是在浏览器向CDN请求资源时,CDN服务才主动向后端的资源服务器抓取资源。国内的提供商有WebLuker

这两种服务,一种推送,一种拉取。后者除了在DNS设置上稍显麻烦外,其它方便性均超过前者,特别是因为内容源在自己的服务器上,可以灵活的设置url,比如动态合并js之类的功能,都可以实现了。

而前者除了多一个存储备份的功能外,内容的组织形式较为死板,必须按照静态目录的方式组织,不适合较为灵活的开发。似乎后者才是大势所趋。

以上是我的看法,不知道各位有没有研究过这两者的优劣,我想后者一直存在一定有它的原因的


回答


1
-----------------------------------------------------
我上个月正好跟又拍云、中国擦车网、快网谈过CDN合作,8年前也用过CDN,来解答一下吧。

  1. 你说的拉取式CDN,本质上是反向代理,甚至有的小CDN厂商找几个机房,搞几台低端硬件,装上squid就开始干活了。国内的代表(是反向代理类的大厂代表,不是小CDN代表啊)应该是中国擦车网(ChinaCache)、快网(FastWeb)、Weblucker
  2. 拉取式和推送式的DNS设置复杂度是完全一样的。不存在谁更麻烦的问题,都是设置DNS CNAME。只不过你在用又拍云的时候根,直接使用了又拍云的子域名,图片不在sfcdn.com这样的域名下,又拍也支持DNS CNAME,绑定你自己的sfcdn.com的。而中国擦车网等均不支持你直接使用CDN厂商的子域名。
  3. 这两者在逐渐融合。中国擦车网也有接口,允许你调用这个接口,主动将你指定的目录/文件同步到CDN节点上。又拍的反向代理模式也即将推出,时间我不知道。
  4. 推送式(又拍)的优点在于节省源站带宽,提前将要分发的内容放到CDN节点上了,当某个流量高峰来临时,不会把你的源站带宽占满(源站还要留点带宽提供动态HTML啊)。打个比方,类似聚划算的每天10点开团,如果没有主动推送,你的源站在10点将会迎来一个流量高峰,你不得不为源站服务器购买更大的BGP带宽,以便CDN每天10点拉文件。缺点是需要针对CDN做接口开发,在被分发内容生成时主动上传给CDN
  5. 抓取式(反向代理)的优点在于实在太简单,签个合同,做个DNS CNAME解析就完成了CDN的实施
  6. 像贵站这样的小公司,没有历史项目的包袱,有自己的研发团队,建议将来重点使用主动推送类的CDN,之所以说是将来,是因为目前又拍自己的中心结点往全国节点同步的时候还存在分钟级的延时,又没其它的同类厂商,给创业企业多一些包容和支持,相信又拍会越做越好。
  7. 动态合并JS不是问题。你完全可以合并好了之后上传到又拍上去,比如10个JS要动态合并,也就100种组合,全部合并好了传上去,HTML中引用合并好之后的js路径,这需要打包发布工具的支持,适合新公司,不适合老公司。
  8. CDN行业不是大家以前想的那种傻大黑粗(跟电信关系好,搞几台机器装squid就开始赚钱了),也有很多公司在研发自己特色的东西,比如fastweb拥有自己的反向代理软件,还有动态内容(PHP,Java)加速服务(意义不是太大,且太贵,我举这个例子只是说他们有研发新东西);比如又拍提供分布式存储和缩略图;比如ChinaCache研发了针对FLV视频网站CDN(这个投资很失败,大视频网站有几个不自己做CDN的啊?土豆跟它的合约一终止,它就开始变卖服务器回笼资金了)
  9. 在中国,大网站最终都要自己做CDN的,像Instagram这样10亿美元了还全部用Amazon的奇葩公司未来5年都不会出现。最终CDN的走向嘛,我想会出现几家综合性的“fastweb+又拍”服务商
2
-----------------------------------------------------

(注意:我没有使用过UpYun,有使用Amazon EC2、S3和CloudFront经验。)

首先纠正一下,Amazon S3需要push,CloudFront是可以设定源进行pull的。


我觉得这里所讨论的似乎并不是CDN的push与pull的问题,而是细分的两种服务,

  • CloudFront 属于CDN加速服务,主要是对公开资源进行加速作用;
  • S3属于存储服务,不一定是公开资源,包括各种私有的备份都可以存放;

我个人倾向:

  • 网站固有的资源文件使用CloudFront进行加速;
  • S3等主要存放一些UGC文件[1],根据cache命中率(譬如多数用户上传的照片可能只有他的朋友能看到,命中机率小)的不同可以选择是否使用CDN加速(而UpYun看起来正是这样的一个CDN与存储的结合体)。

当然CDN也确实有push与pull的区别,如果不是比较大的文件,多数时候pull比较方便。
------
1 - UGC是指用户生成内容,这里主要是用户上传的头像、照片、文件等资源。

3
-----------------------------------------------------

我想首先明白CDN的原理和需要解决的问题就可以很容易取舍了。

CDN无非就是解决静态文件就近访问,达到加速的目的,并且都是反向代理,唯一的区别的就是两者的源不一样。CDN的难点其实不在技术而是在网络和点的分布,还有对ip分布的判断上面。

拉取式,相对简单,但灵活性很大,因为源是由自己控制的,而且还可以配合header头的信息对不同的静态文件进行相应的控制,这个只要跟CDN合作商谈好就行,国内是可以这样的。缺点就是跟推送式的优点。
推送式,灵活性就没有那么大了,源是需要通过一定的方式推送到CDN指定的位置,而且需要配合代码更新和业务需求进行及时的推送,推送式会有一点的延时,主要看CDN商的实现方式和推送API的效率,有些CDN商的推送上去之后还会将数据分发到他们自己不同的服务器存储多份,更有恶心的CDN商,分发是通过计划任务每隔多久进行一次分发,那么延时性就更大。再加上如果一旦内部出现问题排查时间会比较久。但推送式的优点是可以减少源站的网络带宽流量,对于访问量大和延时性不高的业务有非常好的作用,并且多地备份也起到安全性的作用。
取舍就跟你的具体业务有关系了。

另外有提到amazon亚马逊的CDN,就是一个很明显的推送式,一方面是方便他自己的结构,这种方式对于亚马逊也可以很方便和简单的流程控制,另一方面也可以减少流量费用,所以他只采用了这一种方式。
我要提醒一点的是,有缓存就需要有更新,CDN的缓存更新是基本都要涉及的问题,像亚马逊就不支持带参数的方式更新,因为他认为 http://1.t.com/1.jpg和 http://1.t.com/1.jpg?version=2 是同一个url不管?后面的内容,所以你的缓存更新就要想办法啰。

http://segmentfault.com/q/1010000000119794

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值