Google 工程师:为什么 CDN 对移动客户端加速“没有”效果

王者荣耀是近两年来比较火的手游,不少小伙伴都有玩过。玩这个游戏最怕的不是遇到猪一般的队友,也不是怕遇到神一样的对手。最让我们感到害怕和绝望的是,团战爆发时,而你 460 了。460 是一个玩家常用的词,其实它完整表达的是,你的网络延迟达到了 460ms。像王者荣耀这样的游戏,CDN 加速是必须有的。而常常出现 460,难道 CDN 对移动端加速无效吗?

Google Web 性能优化工程师和开发大使、《High-Performance Browser Networking》作者 Ilya Grigorik 近日发布了一篇名为《为什么 CDN 对移动客户端加速“没有”效果》的博客,让我们来看看他在文中讲了什么。

原文链接:https://www.igvita.com/2014/03/26/why-is-my-cdn-slow-for-mobile-clients/

以下是译文:

“我们正在使用 CDN,但是当查看性能数字时,它似乎对移动客户端的效果要差得多。我们正在考虑禁用它,因为不确定它是否对移动端加速有效。有人需要为移动设备建立一个特殊的 CDN,我们肯定会用它来改善延迟!”

随着越来越多的团队专注于提高移动网站的性能,我听到类似论点的频率正在迅速增加。问题是,虽然声明通常基于实际数据,但结论是错误。传统 CDN 对移动客户端和对宽带网络的绝对优化效果差不多;这不是“无线 CDN”的问题,而是运营商网络的问题。

网络延迟的组成

在讨论 CDN 对移动端加速是否有效之前,我们首先要了解延迟是怎么来的。举一个具体的例子,就能非常清晰的了解延迟。让我们假设如下:

  • 客户位于西海岸; 服务器位于东海岸。
  • 美国西海岸和东海岸之间的传播延迟为 50 毫秒。
  • 服务器响应时间为 50 毫秒。
  • “有线”客户端的最后一英里延迟:光纤约为 18 毫秒,电缆约为 26 毫秒,DSL 约为 44 毫秒。
  • “无线”客户端的最后一英里延迟:4G 约为 50 毫秒,3G 约为 200 毫秒。

CDN 加速效果

CDN 加速是尽可能地将字节移动到用户附近,在全球各个数据中心和对等点内部署缓存服务器。换句话说,在最佳情况下,CDN 服务器位于 ISP /运营商网络之外:客户端发出请求,导致退出 ISP /运营商网络的最后一英里延迟的成本,并立即命中返回的 CDN 服务器一个回应。因此,CDN 最大限度地减少了传播延迟,还可以通过返回缓存的静态资源来缩短服务器响应时间。

继续之前的示例,假设我们的 CDN 服务器是最佳放置的(东海岸到西海岸的延迟时间不是 50ms 而是 5ms),而且请求 CDN 未命中源站的情况下客户端到 CDN 节点的延迟是 5ms。对于我们的光纤客户端,新的总时间是最后一英里往返加上 CDN 响应时间的总和:18 + 5 + 5 + 5 + 18,总共 51 毫秒。因此,增加 CDN 的好处就是将我们总请求时间由 186ms 降低到了 51ms:在总延迟上有 365% 的改善!

采用同样的方法重复计算每个连接的基本信息,就可以得到一个不幸的趋势:

  • 随着最后一英里延迟的增加,CDN 的相对有效性“下降”。
  • 考虑CDN服务器位于 ISP 网络之外,这就意味着节点的选择非常有意义
  • 无论最后一英里的延迟如何,绝对延迟的改善仍然是有效的。

CDN 有助于减少传播和服务器响应时间。如果你衡量优化前后的对比,就会发现 CDN 几乎没有做移动客户端的优化:例如,3G 用户普遍获得 33% 的优化效果,而 4G 用户普遍获得了 117% 的优化效果

在边缘节点上的运营和维护成本

改善端到端延迟的明显策略是将缓存服务器更加靠近客户端,而不是将它们放在 ISP 网络之外。我们可以将它们移到内部吗?原则上,答案是肯定的,许多 ISP 已经部署了自己的缓存服务器。但是,在实践中,这是一个棘手的问题。

首先,对等点的数量相对较少,这允许 CDN 部署在全球数十个众所周知的位置以提供其服务。此外,为此,他们不必与各个 ISP 进行任何特殊交易:通常,服务器部署在共享数据中心(对等点)中。

我们假设 CDN 和某个 ISP 达成协议,理想情况下尽可能将服务器部署靠近客户(靠近无线电塔和其他聚合点)。这样做需要大量硬件,使维护和升级成为运维的噩梦,并且会导致许多安全问题。例如,您是否会在无法直接访问的第三方运营网络中部署 TLS 终端节点?总之,这是成本,安全和物流的噩梦。

许多互联网服务提供商长期以来一直试图推动“高端市场”并提供 CDN 功能。然而,ISP 有一个不同的问题:他们很难签署客户,因为大多数网站对于和每个运营商单独签署协议丝毫不感兴趣。

除了业务和运营成本之外,为移动客户优化 CDN 没有什么特别之处。根本问题是移动运营商的最后一英里延迟是残酷的,这就是我们需要解决的问题。我们需要透明地了解这些网络的性能,而不是将缓存服务器推向更接近边缘的地方,我们需要运营商之间更多的竞争来解决潜在的最后一英里性能问题。

简而言之,没有理由为什么 CDN 本身对移动客户来说“慢”:不要将相对收益与绝对节省混为一谈。也就是说,每个 CDN 提供商的实际性能显然会根据其服务器的位置和与各种移动运营商的连接而变化,测量,收集实际数据,进行优化。CDN 对移动设备来说并不慢,使用它们!

又拍云 CDN 结合高效链路优化,智能网络调度以及强大的内容匹配等技术,让移动应用在公网拥堵、弱网、不同终端等应用场景中,依旧能够快速获取到动态、静态内容,轻松提升 30% 访问速度。

推荐阅读:

又拍云 OpenResty / Nginx 服务优化实践?

了解 HTTPS,读这篇文章就够了?

原文地址:https://www.cnblogs.com/upyun/p/10253865.html

时间: 2024-10-15 01:22:58

Google 工程师:为什么 CDN 对移动客户端加速“没有”效果的相关文章

AWS CloudFront CDN直接全站加速折腾记The request could not be satisfied. Bad request

ERROR The request could not be satisfied. Bad request. Generated by cloudfront (CloudFront) Request ID: JC3i8piJpjRbuP81MNhSKPxt5KWirIInynZgwFJ9EYKuysjS5A_AnQ== 上面这个问题害我着急的很啊.在这里谢谢远在东京的小伙伴在百忙之中帮我分析解决这个问题. 使用AWS也有段时间了,基本常用的服务都用了,还有很多服务没用上,正在慢慢摸索中..说实话

盘点国内网站常用的一些 CDN 公共库加速服务

CDN公共库是指将常用的JS库存放在CDN节点,以方便广大开发者直接调用.与将JS库存放在服务器单机上相比,CDN公共库更加稳定.高速.一 般的CDN公共库都会包含全球所有最流行的开源JavaScript库,你可以在自己的网页上直接通过script标记引用这些资源.这样做不仅可以为您 节省流量,还能通过CDN加速,获得更快的访问速度. 目前国内的一些比较大的公共CDN服务: 百度CDN公共库 百度公共CDN为站长的应用程序提供稳定.可靠.高速的服务,包含全球所有最流行的开源JavaScript库

Google工程师解析Android系统架构

导读:Sans Serif是Google的一位工程师,近日发布了一篇博文非常清楚的描述了Android系统架构,中国移动通信研究院院长黄晓庆在新浪微博上推荐了该文,并认为文中对Android的介绍很好,如下是CSDN对文章的简单编译: Andriod是什么? 首先,就像Android开源和兼容性技术负责人Dan Morrill在Android开发手册兼容性部分所解释的,"Android并不是传统的Linux风格的一个规范或分发版本,也不是一系列可重用的组件集成,Android是一个用于连接设备的

CDN技术的加速原理

"加速!"在这个快节奏的时代,已经成了人们习惯的模式.所以网民对网络的要求也越来越高,网站的速度成了最明显的竞争力.cdn加速则是将网站的内容缓存在网络边缘,当用户访问时,通过调度系统将用户的请求引导到具体用户接入最近的服务器上,由这个缓存的服务器为用户提供内容的服务.通过这种方式缩短用户的内容之间的距离,从而到达加速的效果. 正因如此,cdn加速被广泛应用到各个网站,上面提到的cdn网站加速只是一种极为普遍的加速显现,接下来详细介绍使用cdn加速优势: 1.本地加速 提高了企业站点的

Google工程师打造Remix OS系统 桌面版安卓下载

三位前Google工程师打造的Remix OS系统终于来到了PC桌面上,现已可以下载尝鲜. Remix OS for PC基于Android-x86项目,由安卓5.1 Lollipop深度定制而来,不但兼容所有安卓应用和游戏,还针对桌面应用环境增加了各种使用功能,堪比Windows,并且能与Windows.Mac OS X系统共存. 本次放出的是Alpha预览版,版本号2016011201,体积约692.15MB,主要面向开发者和尝鲜者,可能会存在不稳定问题和很多Bug. 安装需要通过U盘进行,

[jQuery编程挑战]001:实现页面元素加速动画效果

要求: 页面包含两个HTML元素:一个按钮,一个小方块 动画要求:点击按钮,小方块从页面坐标300,300,加速移动到0,0 相关知识点: jQuery动画方法animate easing参数的设置 <!DOCTYPE html> <html lang="zh"> <head> <meta charset="utf-8"> <title>实现页面元素加速动画效果</title> <styl

自定义加速球效果

一个自定义控件: 地址: git:https://github.com/guoGavin/CustomAccelerateBall csdn:http://download.csdn.net/detail/jiguangcanhen/8687305 accelerate ball,加速球效果,也就是圆形的ProgressBar的效果. 效果图 录制效果不是很好 功能 可以设置目标位置,让它自己加速到特定位置. 可以设置不适用加速的动画效果,直接设置到特定位置. 可以设置是否显示Percent.

国内网站常用的一些 CDN 公共库加速服务

CDN公共库是指将常用的JS库存放在CDN节点,以方便广大开发者直接调用.与将JS库存放在服务器单机上相比,CDN公共库更加稳定.高速.一 般的CDN公共库都会包含全球所有最流行的开源JavaScript库,你可以在自己的网页上直接通过script标记引用这些资源.这样做不仅可以为您 节省流量,还能通过CDN加速,获得更快的访问速度. 为便于广大程序员的选择.使用,本文将网上的多篇文章合并为此文. 百度CDN公共库 百度公共CDN为站长的应用程序提供稳定.可靠.高速的服务,包含全球所有最流行的开

盘点国内网站常用的一些 CDN 公共库加速服务(转载)

http://www.cnbeta.com/articles/304469.htm 目前国内的一些比较大的公共CDN服务: 百度CDN公共库 百度公共CDN为站长的应用程序提供稳定.可靠.高速的服务,包含全球所有最流行的开源JavaScript库. 官网:http://developer.baidu.com/wiki/index.php?title=docs/cplat/libs Ps:百度的速度目前来说应该是和新浪差不多的.不过jQuery的版本比SAE少几个,其他类库应该都差不多. 新浪云计