CDN具体解释(篇一)
CDN是一个致力于使内容传输更快、更高效的针对webserver的全局分布式网络。通过CDN来复制使这些内容能够在非常多地方同一时候存在。
比較有名的CDN厂商有AKamari,Amazon Cloudfont以及Edgecast。
为什么CDN会存在?最根本的原因...获得更好的用户体验。并且第二层优点是能够使网络资源更有效的被利用。
CDN主要使用双方面的技术来实现:
保持重要的内容分布在多个全局的分布式数据中心。从而使关键数据离终端用户更近,也使得下载起来更快。
使用基于内容类型的服务端优化技术能够使用户以最高效的方式获取须要的内容。
首先让我们看一下通常情况下webserver是怎样向用户浏览器数据传输的。
用户发出请求来下载一个web页面,这一般是通过点击一个链接来请求。
用户浏览器发送一个请求到webserver来请求对应内容。
webserver開始回传所请求页面的全部内容。这通常包含很多独立的资源。
很easy的东西。
普通情况下,和用户请求相关的内容都会去同一个webserver上请求,而请求者(如:浏览器)则不关心所请求内容的位置和类型。对于真正的大型站点来说或许会有一个负载均衡的webserver池,可是再从普通情况来看,这些webserver都在同一个数据中心。
但 是在简单的表象之下,还有非常多事情要做。须要有一个DNS解析器来获取webserver的ip地址。webserver通常须要回传很多不同类型的内容到浏览器。 如:图片、JavaScript脚本、CSS、文本文件、视频以及页面包括的全部其它内容。
一个典型的web页面会包括非常多这种内嵌资源并且都会发送到 浏览器--通常有超过60个不同的文件要读取,有时在一个请求中会包括超过100个资源文件!此外。有的请求为了可以渲染出所请求的内容还须要浏览器去做 一些额外的请求操作。
我们能够将所请求的内容分成下面几种不同的类型:
动态内容:这些内容是由webserver通过如php,ruby或者java等web编程语言凭空生成的。
静态内容:这些内容一般是常常变化并且不须要生成。图片、CSS样式文件、javascript脚本文件都属于这类内容。
流媒体内容:视频或音频等须要浏览器来控制播放的文件。
这 些类型的文件差别太大以致于没有一个server可以非常好的为全部类型的文件提供服务。
每种类型的文件都有不同的要求和优化方式。动态内容须要占用server大量的 内存和CPU资源。却非常少占用带宽;静态内容和流媒体内容恰恰相反,占用相对较少的内存资源,却占用非常大带宽。假设非要在同一台server上来处理两个场景将 会使双方面都会变的更糟:webserver一方面要载入动态内容须要的内存,还有一方面为所须要的非动态内容做准备。至少对同一台server来说,这双方面不能同一时候 做到最好。
(未完。待续。。
。)
1. 本文由程序猿学架构翻译
2. 本文译自Performance Blog: Content Delivery Networks (CDN) Explained
3. 转载请务必注明本文出自:程序猿学架构(微信号:archleaner
)
4. 很多其它文章请扫码:
CDN具体解释(篇一)的更多相关文章
- CDN具体解释(篇二)
还有还有一个问题就是全部的内容都放在同一个地方.假设我们的server在芝加哥,那么美国中西部的人们訪问server的响应时间和用户体验就比香港.德国.南非以及佛罗里达州的用户好.由于那些用户离ser ...
- 程序员要搞明白CDN,这篇应该够了
最近在了解边缘计算,发现我们经常听说的CDN也是边缘计算里的一部分.那么说到CDN,好像只知道它中文叫做内容分发网络.那么具体CDN的原理是什么?能够为用户在浏览网站时带来什么好处呢?解决这两个问题是 ...
- Android开发四大组件之Service(具体解释篇)
Android开发之四大组件--Service 一.Service 简单介绍 Service是android系统中的四大组件之中的一个(Activity.Service.BroadcastReceiv ...
- ReactiveCocoa概念解释篇
1.ReactiveCocoa简介 ReactiveCocoa(简称为RAC),是由Github开源的一个应用于iOS和OS开发的新框架,Cocoa是苹果整套框架的简称,因此很多苹果框架喜欢以Coco ...
- iommu系列之---概念解释篇
本文会对iommu中的一些容易引起疑惑的概念进行阐述,内核版本为4.19. 先上简写: DMAR - DMA remapping DRHD - DMA Remapping Hardware Unit ...
- 看上去很美 国内CDN现状与美国对比
CDN的理想与现实 多年以前,当<Kingdom of Heaven>这部史诗电影发行的时候,中国的影迷使用电驴和BT来寻找种子,而那个时候,高清也才刚刚进入电影领域,我的同事不惜用自家的 ...
- 雅虎(yahoo)前端优化十四条军规
第一条.尽可能的减少 HTTP 的请求数 (Make Fewer HTTP Requests ) http请求是要开销的,想办法减少请求数自然可以提高网页速度.常用的方法,合并css,js(将一个页面 ...
- TGL站长关于常见问题的回复
问题地址: http://www.thegrouplet.com/thread-112923-1-1.html 问题: 网站配有太多的模板是否影响网站加载速度 月光答复: wp不需要删除其他的模板,不 ...
- Yahoo前端优化十四条军规
相信互联网已经越来越成为人们生活中不可或缺的一部分.Ajax,flex等等富客户端的应用使得人们越加“幸福”地体验着许多原先只能在C/S实 现的功能. 比如Google机会已经把最基本的office应 ...
随机推荐
- 模板 SBT
傻逼树模板 struct SBT{ const static int maxn = 1e5 + 15; int lft[maxn] , rht[maxn] , key[maxn] , s[maxn] ...
- 重温JavaScript获取CSS样式的方法(兼容各浏览器)
众所周知,CSS样式有三种类型:行内样式.内部样式和外部样式,JavaScript获取CSS样式时分为两种情况:行内样式获取法 和 非行内样式获取法 . 一.行内样式获取相对简单,通过element. ...
- Oracle中NVARCHAR2与VARCHAR2的相互转换
将NVARCHAR2转换为VARCHAR2: declare v_username varchar2(12) ; v_nm_login nvarchar2(12); begin selec ...
- Blocks与Dispatch Queue的使用
block是什么block是一个C level的语法以及运行时的一个特性,和标准C中的函数(函数指针)类似.用于回调函数的地方.两个对象间的通讯.实现轻量级的“代理”. blocks和C语言函数指针的 ...
- 【mysql】在mysql中更新字段的部分值,更新某个字符串字段的部分内容
在mysql中更新字段的部分值,更新某个字符串字段的部分内容 sql语句如下: update goods set img = REPLACE(img,'http://ozwm3lwui.bkt.clo ...
- Selenium2+python自动化51-unittest简介
前言 熟悉java的应该都清楚常见的单元测试框架Junit和TestNG,这个招聘的需求上也是经常见到的.python里面也有单元测试框架-unittest,相当于是一个python版的junit. ...
- 序列化人人网框架下的DAO?也就是在Spring下序列化DAO的问题(spring+quartz集群下)
人人网框架地址:http://code.google.com/p/paoding-rose/ 问题发生: 用Quartz作集群时用JobDataMap传递DAO,提示DAO未序列化,可框架的DAO为接 ...
- iptables配置实践
前言 在大企业中防火墙角色主要交给硬件来支持,效果自然没话说只是需要增加一点点成本,但对于大多数个人或者互联网公司来说选择系统自带的iptables或者第三方云防火墙似乎是更加合适的选择,通过一些合理 ...
- 使用HTML5画柱状图
柱状图在很多应用中都比较常见,例如投票结果的统计分析,企业销售数据的统计分析等等. 需求分析: 一个柱状图一般包含以下几部分: 1.标题 2.横坐标(含标题) 3.竖坐标 (含标题.刻度 ...
- easyui-datetimebox设置默认时分秒00:00:00
datetimebox默认打开面板显示的是当前的时间,有个需求就是当打开面板时显示固定的”00:00:00”时间, 它本身有个方法spinner方法可以获得时间微调器对象,它所依赖的组件combo有个 ...