CDN(Content Delivery Network)技术原理概要
简介
- CDN(Content Delivery Network)即内容分发网络,依靠部署在各地的边缘服务器,通过中心平台的负载均衡、内容分发、调度等功能,使用户就近获取所需内容,提高用户访问响应速度和命中率。---- 来自:CDN百度百科
举个简单的例子:让原本上海的浏览器要访问北京主站内容的请求,转而由部署在上海或其他地方的缓存来受理,这样请求的数据只需要经过很短的距离就能够到达请求端,有效利用带宽并降低主站压力
工作原理
- CDN网络一般分为中心节点和边缘节点
- 中心节点功能:监控边缘节点的情况(可用性,拥塞程度),全局负载均衡管理,与主站点进行数据同步
- CDN工作原理:
浏览器访问一个网站所经历的步骤- 未加CDN缓存的网站
- 用户在浏览器地址栏输入要访问的域名
- 浏览器解析域名得到对应的IP地址,再向此IP地址的服务器发出访问请求
- 浏览器根据服务器返回的东西显示网页内容
- 加CDN缓存的网站
- 用户在浏览器中输入要访问的域名
- 浏览器对域名解析,(CDN对域名解析过程进行了调整)得到该域名的CNAME记录,然后利用全局的负载均衡DNS解析得到实际的IP地址
- 浏览器在得到了实际的IP地址(缓存服务器的IP)后向缓存服务器发出访问请求
- 缓存服务器根据浏览器提供的要访问的域名通过DNS解析得到该域名对应的实际的IP地址,然后该缓存服务器向此实际IP地址提交访问请求
- 缓存服务器从实际IP地址得到内容后,进行两个操作:
- 将得到的内容保存到本地,以便以后使用
- 将获取的内容返回给客户端,完成数据服务过程
- 未加CDN缓存的网站
- 示例:
- 如图所示:

- 浏览器访问站点的步骤:
- 用户在浏览器的地址栏中输入www.web.com,然后回车,浏览器发现本地没有DNS缓存,就向网站的DNS服务器请求
- 网站的DNS域名解析器设置了CNAME,指向了www.web.51cdn.com(CDN只能接职能负载均衡系统)
- 职能DNS负载均衡系统解析域名,把对用户响应速度最快的IP节点返回给用户
- 浏览器向该IP节点发送请求
- 第一次访问的时候,CDN服务器请求原web站点,得到内容后一方面将得到的内容缓存到本地;另一方面将请求的结果返回给客户端(下次访问的时候,如果节点的缓存内容可用的话,就不会再请求原web站点了)
- 如图所示:
- CDN关键技术
CND关键技术有:内容路由技术、内容分发技术、内容存储技术、内容管理技术- 内容路由功能
- CDN的负载均衡系统实现CDN的内容路由功能。CDN内容路由功能作用使用户请求到达CDN网络中的最佳节点
- 全局负载均衡主要目的是让用户的请求到达CDN网络中最近的节点
- 局部负载均衡 在特定的范围内寻找一台合适的节点提供服务(要考虑到节点的健康性、负载情况、支持的媒体格式等运行状态)
- 内容分发技术
内容分发技术主要是PUSH和PULL- PUSH是一种主动分发的技术,通常由内容管理系统发起,将内容从源或者中心媒体资源库发布到各个边缘的Cache节点(HTTP/FTP)
- PULL 是一种被动的分发技术,当用户请求的内容不在请求所达到的边缘Cache的节点上时,该节点会从内容源或其他节点PULL下所需的内容(按需分发)
- 内容存储技术
- 内容源的存储
通常采用海量存储架构(内容的规模及吞吐量较大) - 在Cache节点中的存储
Cache节点的存储要考虑:- 功能上,对各种内容格式的支持、对部分缓存的支持
- 性能上,容量大小,吞吐率、可靠性及稳定性
- 内容源的存储
- 内容管理技术
本地内容管理(对Cache节点而言)的目标是提高内容服务的效率,提高本地节点的存储利用率。- 本地内容索引是实现基于内容感知调度的关键
- 本地内容的复制。通常为了提高存储的效率,同一个内容只在某个特定的节点中存储一份,当对该内容的访问超过这个节点的能力范围,就将该内容进行分发到其他节点上
- 本地内容访问状态的收集。搜集各个节点上各个内容访问的统计信息,节点可用服务能力及内容变化的情况
注:在这里只是简单介绍了一下这几种技术,并不是特别详细,先对这些有个大概了解,方便以后的学习,如果感觉本文的内容说的不具体的话可以看一下这篇文章:CDN技术详解及实现原理,因为有些东西我还不懂,所以有些内容还未涉及到,请大家见谅。
- 内容路由功能
注:本文参考 CDN 及 CDN的四大关键技术
如需转载请注明出处:http://www.cnblogs.com/zhuchenglin/p/8978600.html
我的博客即将搬运同步至腾讯云+社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-plan?invite_code=24pg1rt5k61ws
CDN(Content Delivery Network)技术原理概要的更多相关文章
- web网站加速之CDN(Content Delivery Network)技术原理
在不同地域的用户访问网站的响应速度存在差异,为了提高用户访问的响应速度.优化现有Internet中信息的流动,需要在用户和服务器间加入中间层CDN. 使用户能以最快的速度,从最接近用户的地方获得所需的 ...
- CDN(Content Delivery Network)内容分发网络
CDN的全称是Content Delivery Network,即内容分发网络.其基本思路是尽可能避开互联网上有可能影响数据传输速度和稳定性的瓶颈和环节,使内容传输的更快.更稳定.通过在网络各处放置节 ...
- CDN(Content Delivery Network)原理
CDN即内容分发网络,一般包括分发服务系统,负载均衡系统和管理系统. 分发服务系统,其基本的工作单元就是各个cache服务器.负责直接响应用户请求,将内容快速分发到用户:同时还负责内容更新,保证和源站 ...
- CDN的全称是Content Delivery Network,即内容分发网络
CDN的全称是Content Delivery Network,即内容分发网络 http://baike.baidu.com/link?url=Wd-IGGgslfJemdpuT3Y0BUi88RPQ ...
- 深度剖析:CDN内容分发网络技术原理--转载
1.前言 Internet的高速发展,给人们的工作和生活带来了极大的便利,对Internet的服务品质和访问速度要求越来越高,虽然带宽不断增加,用户数量也在不断增加,受Web服务器的负荷和传输距离等因 ...
- CDN(Content Distribution Network)概念
CDN的全称是Content Delivery Network,即内容分发网络.其基本思路是尽可能避开互联网上有可能影响数据传输速度和稳定性的瓶颈和环节,使内容传输的更快.更稳定.通过在网络各处放置节 ...
- Content Delivery Network
Coding Standards & Best Practices 7 Reasons to use a Content Delivery Network CDN公共库汇总
- CDN(内容分发网络)技术原理
1. 前言 Internet的高速发展,给人们的工作和生活带来了极大的便利,对Internet的服务品质和访问速度要求越来越高,虽然带宽不断增加, 用户数量也在不断增加,受Web服务器的负荷和传输距离 ...
- [转]CDN(内容分发网络)技术原理
1. 前言 Internet的高速发展,给人们的工作和生活带来了极大的便利,对Internet的服务品质和访问速度要求越来越高,虽然带宽不断增加, 用户数量也在不断增加,受Web服务器的负荷和传输距离 ...
随机推荐
- ABP代码生成器与升级到VS2017VSIX
首先,我不是要分享一个代码生成器,而是怎么升级到VS2017,简单介绍下 如何将2015的VSIX项目升级到2017 阳光铭睿 写了一篇<分享一个与ABP配套使用的代码生成器源码>,并在群 ...
- 在虚拟机里连接PLC S7-200
1-使用PPI线连接 这次选择了在虚拟机里面来调试PLC,s7-200的型号是214-2AD23-0XB8 ,连接线是在淘宝上卖的(连接),在虚拟机里面试的时候没有反应,如下 在设备管理器里面观察,在 ...
- Python爬虫基础之Cookie
一.Cookie会话 简单地说,cookie就是存储在用户浏览器中的一小段文本文件.Cookies是纯文本形式,它们不包含任何可执行代码.一个Web页面或服务器告之浏览器来将这些信息存储并且基于一系列 ...
- SecuerCRT遇到一个致命错误且必须关闭_解决方案_软件链接(自己百度云盘的)
问题描述: 1.以前安装过SecureCRT,现在出现问题,手工卸载不完全,导致新安装的SecureCRT一直提示:以下错误. 2.出现的错误: 3.解决方案: 1)删除,上图路径中VanDyke文件 ...
- C++智能指针剖析(下)boost::shared_ptr&其他
1. boost::shared_ptr 前面我已经讲解了两个比较简单的智能指针,它们都有各自的优缺点.由于 boost::scoped_ptr 独享所有权,当我们真真需要复制智能指针时,需求便满足不 ...
- Python-数据类型之字典
一: 概述 字典是有大括号,逗号分隔,有k/v组成 字典的键必须hashable,如数字,字符串,布尔值,元组 二: 操作 2.1 增 2.1.1 直接赋值 如果键不存在,则增加 dic = {'n ...
- Nginx+IIS+asp.net mvc 实现负载均衡示例
一.Nginx官网 http://nginx.org/ 二.下载并安装Nginx 下载地址:http://nginx.org/en/download.html 启动Nginx,启动成功的话可以在任务管 ...
- EF core的模型映射
在EF core里,可以通过实现IEntityTypeConfiguration来进行映射. 一.官网文档 https://docs.microsoft.com/en-us/ef/core/what- ...
- python 将png图片格式转换生成gif动画
先看知乎上面的一个连接 用Python写过哪些[脑洞大开]的小工具? https://www.zhihu.com/question/33646570/answer/157806339 这个哥们通过爬气 ...
- Selenium之Selenium IDE
官方文档:https://www.seleniumhq.org/docs/02_selenium_ide.jsp 1. Selenium IDE介绍 Selenium IED (Integ ...