欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  科技

001.CDN概述

程序员文章站 2023-08-28 20:40:12
一 互联网应用质量概述1.1 互联网应用质量互联网应用质量指标——QoE,其主要指标:服务成功率:指用户所请求的服务成功完成的几率。服务建立时间:指从服务请求到服务呈现所花费的时间,并且会因为用户请求服务内容的不同而表现出微妙到秒级的区别。时延:指用户从发出请求到获得结果的时间。视听播放卡顿:指播放... ......

一 互联网应用质量概述

1.1 互联网应用质量

互联网应用质量指标——qoe,其主要指标:
服务成功率:指用户所请求的服务成功完成的几率。
服务建立时间:指从服务请求到服务呈现所花费的时间,并且会因为用户请求服务内容的不同而表现出微妙到秒级的区别。
时延:指用户从发出请求到获得结果的时间。
视听播放卡顿:指播放音频或视频时,由于没有接收到足够的数据或较低的帧传输速率而引起的播放暂停的现象。
图像清晰度:指图片会视频画面上的细节信息和边界信息的清晰程度以及精确还原实物色彩的能力。

1.2 网络性能——时延

完整时延:终端处理指令时延——>网络时延——>服务器响应时延——>网络时延——>终端处理响应时延。
网络时延:指数据分组穿越一个或多个网段所经历的时间。其中路由处理、adu(用户数据单元)的传输、服务器对用户请求的处理以及距离产生的网络传输时延,构成了网络时延的主要因素。
发送时延:指在发送数据时,数据从发送端进入传输介质所消耗的时间。发送时延=数据帧长度/发送速率。
传播时延:指电磁波在传播过程中消耗的时间。传播时延=传播距离/传播速率。
处理时延:指服务器或路由器接收到数据分组时,会检测数据分组的头部,决定将该数据分组传输到哪一个链路上所需的时间。
排队延时:指pdu在传输链路上每一个排队等待所引起的时间延时的集合。

1.3 网络性能——qos

网络的时延、抖动、带宽以及分组丢失统称为服务性能(qos)指标,可理解为底层分组数据传输的性能指标。

二 常见互联网应用部署

2.1 集中式部署

集中式部署存在单点问题,同时不利益系统的扩容,也会带来网络时延过大的问题。

2.2 利用网站镜像加速

网站镜像是通过复制整个网站或部分网页内容并将其重新存储到其他服务器,让用户在新服务器依然能够访问想获得的内容,并且为主站分担了网络流量。
网络镜像在需要重复上传的内容过多时会显得非常麻烦,通常商业网站一般并不采用镜像的方法。

2.3 cdn进行加速

cnd=智能的镜像+缓存+流量调度,cnd主要优势如下:

  • 缓解源站服务器访问压力;
  • 优化热点内容的分布,合理缓存,减轻骨干网传输的流量压力;
  • 提升用户的访问质量和体验,全面提高网站访问速度;
  • 增强网站服务的可靠性,解决网站突发峰值流量问题;
  • 解决不同运营商之间互联互通问题造成的影响;
  • 提高安全性,有效防止异常流量对源站的攻击。

三 cdn基本概念

3.1 cdn的定义

内容分发网络(content delivery network)是在现有网络中增加一层新的网络架构,从而实现将源站内容发布和传送到最靠近用户的边缘地区,使用户可以就近访问想要的内容,提高用户访问的响应速度。
内容:cdn的内容通常是以下两种:静态内容以及动态内容。
分发:cdn的分发是指利用一定的传送策略,将用户请求的内容发布到距离该用户最近的节点。
网络:cdn由多个(通常成千上万)分布式服务器组成,通过服务器的通信,把内容分发和传送给终端用户。cdn各节点之间是通过电信运营商的宽带网络进行通信,即cdn网络是在电信运营商的网络之上的一层网络。

3.2 cdn基本原理

依靠放置在各地的缓存服务器,通过全局调度以及内容分发等功能,将用户需要的部分内容部署到最贴近用户的地方,将原本低效、不可靠的ip网络转变成高效、可靠的智能网络,满足用户对内容访问质量的更高要求,改善互联网网络拥塞问题,提高用户访问网站的响应速度。

四 cdn工作过程

4.1 基本工作过程

  • 内容注入:内容注入是cdn能为用户提供服务的第一步,是内容从源站注入cdn的过程,使得用户能从cdn系统中获取源站的内容;
  • 用户请求调度:用户请求调度是用户向网站发起请求,最终用户被引导到最佳的有内容的cdn节点的过程。
  • 内容分发:将用户所需访问的内容分发到用户,或从上级节点拉去内容后,将内容分发到下级节点。
  • 内容服务:将找到的最靠近用户的cdn节点中的内容交付给终端用户。

4.2 cdn内容接入

  • 内容存储接入:指源站在发布内容前,提前将内容注入到cdn中。采取此方式接入的内容将永久存储在cdn中,直到通过内容接入操作指令对该内容显式删除。
  • 内容预注入:指源站在发布内容前,提前将内容注入到cdn中。但采用此方式接入的内容并不会永久存储在cdn中,而仅仅是进行内容缓存,cdn会根据内容访问的热度情况对缓存的内容进行智能删除。
  • 实时回源:指源站在内容发布之前不向cdn注入内容,但当用户内容访问请求时,cdn实时地从源站拉取内容。

4.3 cdn用户请求调度

全局调度:根据用户所在地理位置不同,在各个节点之间进行分析决策,将用户请求转移到整个网络中最靠近用户的节点。
本地调度:通常被限制在一顶地区范围内,并且更加关注cdn服务器设备具体的健康情况与负载情况,根据实时响应时间,将任务分配给最适合的服务器设备进行处理,实现更精细粒度的调度决策。

4.4 cdn内容分发

push方式:一种主动分发的方式,由cdn内容管理系统发起,将内容从源站或者中心内容库主动分发到各边缘的cdn节点,分发协议通常有http、ftp等。
提示:通过push分发的内容一般是比较热点的内容,通过push方式预先主动分发到边缘cdn节点,可实现有针对性的内容提供,属于一种智能的主动分发策略。
pull方式:一种被动分发的方式,由用户请求驱动,当用户请求的内容在本地的边缘cdn节点上不存在(未命中)时,该cdn节点启动pull方式从内容源或其他cdn节点实时拉取内容,在pull方式下,内容是按需分发的。
提示:通过pull分发的内容一般访问比较集中,例如热点的流媒体内容,pull方式比较适合内容访问分散的情况。
混合分发方式:push和pull两种方法结合的一种机制。一般利用push方法进行内容预推,pull方式拉取。

4.5 cdn内容服务

cdn内容服务根据用户访问的内分为静态内容服务、动态内容服务。