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应 ...
随机推荐
- BZOJ5137[Usaco2017 Dec]Standing Out from the Herd
看了半天题 不知道怎么用SAM维护 于是借(chao)鉴(xi)的一发神犇的 只要判断这个子串之前被标记的记号(也就是他属于第几个串)和这次转移到的是否相同 如果不同就说明该子串属于多个串 直接标记- ...
- python MySQL 获取全部数据库(DATABASE)名、表(TABLE)名
import MySQLdb #connect try: conn = MySQLdb.connect( host = "localhost", user = "root ...
- MySql篇
CentOS6下通过yum安装的MySQL是5.1版的,比较老,所以就想通过源代码安装高版本的5.6.26. 一:卸载旧版本 使用下面的命令检查是否安装有MySQL Server rpm -qa | ...
- Linux与Windows比较出的20个优势
Linux相信大家并不会陌生,Android(安卓或安致)就是基于Linux平台的开源手机操作系统,在电脑方面有ubuntu(中文名:乌班图)等等也是基于linux. Windows与Linux Li ...
- GDB 自动化操作的技术-PYTHON
https://github.com/spacewander/debugger-utils http://python.jobbole.com/85415/ https://segmentfault. ...
- 多线程调试必杀技 - GDB的non-stop模式
作者:破砂锅 (转) 开源的GDB被广泛使用在Linux.OSX.Unix和各种嵌入式系统(例如手机),这次它又带给我们一个惊喜. 多线程调试之痛 调试器(如VS2008和老版GDB)往往只支持a ...
- Geeks 一般二叉树的LCA
不是BST,那么搜索两节点的LCA就复杂点了,由于节点是无序的. 以下是两种方法,都写进一个类里面了. 当然须要反复搜索的时候.能够使用多种方法加速搜索. #include <iostream& ...
- .NET泛型04,使用Lazy<T>实现延迟加载
对于一些"大对象"的创建,我们常常希望延迟加载,即在需要的时候再创建对象实例.现在Lazy<T>很好地支持了这一特点.主要包括: 没有Lazy<T>之前 L ...
- MySQL 5.5版本解决中文乱码问题时my.ini内[mysqld]项中不能再写default-character-set=utf8
来看看如何解决乱码问题: 在mysql中默认字符集是latin1, 想要设置字符集为uft-8,可以在 my.cnf 文件中添加以下设置: [client] default-character-set ...
- iOS 5解决Could not instantiate class named NSLayoutConstraint问题
如果使用Xcode 4.5来新建项目,默认是支持AutoLayout的,但是AutoLayout是iOS 6的新特性,如果在iOS 5的simulator上运行程序,会出现Could not inst ...