JavaWeb深入分析(3)CDN

cdn (Content Delivery NetWork) 内容分发网络,它是构筑在现有互联网基础上的一种先进的流量分配网络。区别于镜像,相当于是 CDN = 镜像(mirror) +
缓存(Cache)+整体负载均衡(GSLB)。目前CDN 都已缓存网站中的静态数据为主,如CSS,JS,图片和静态页面等数据,用户从主服务器上请求到动态页面之后,再从CDN上下载这些静态数据,从而加速访问。

CDN目标:

  • 可扩展性(Scalebility) 应对新增大量的数据,用户和事务的扩展性。低成本提供高质量的内容分发。
  • 安全性(Security) 强调安全问题。
  • 可靠性。容灾和负载均衡咯。

CDN架构:
如图用户去访问一个假设是css文件,先是想localserver发起请求,然后迭代解析回到这个域名的注册服务器去解析,然后通过cname解析到CDN全局负载均衡服务器,然后用户直接去这个CDN节点访问这个css文件咯,如果不存在就去源站请求。
JavaWeb深入分析(3)CDN

3种负载均衡

  • 链路负载均衡:dns服务器进行负载均衡,在解析中完成。
    JavaWeb深入分析(3)CDN

  • 集群负载均衡:分为硬件和软件

     - 硬件:非常昂贵的硬件设备,如F5 开始一旦坏掉就GG 

JavaWeb深入分析(3)CDN

 - 软件: 通过代理服务器,可能会增加网络延时。LVS在IP层进行地址转发,HAProxy根据HTTP请求头进行转发。 

JavaWeb深入分析(3)CDN

  • 操作系统负载均衡:利用操作系统的软中断和硬中断,来达到负载均衡。

CDN动态加速:这个是目前比较流行的一种优化技术。原理其实就是在CDN的DNS解析中通过动态链路探测技术来找到回源最好的一条路径,然后通过dns的调度将后面所有的请求都选在这条特定的路径上,从而加速用户的访问效率。所以一个用户在CDN节点遍布全国的情况下从一个CDN节点接入之后,可以选择一个最好的源站链路给用户。简单的方法就是每条链路去下一个特定大小的文件,然后找出这个链路列表里面耗时最小的。其实还要考虑带宽和安全等等成本。

如下图就是一个就是一个使用CDN加速网站访问的架构示意图
JavaWeb深入分析(3)CDN

其中还包括了网站分布式文件系统、noSQL和搜索引擎技术等。

专注于JavaWeb

原文链接:https://www.cnblogs.com/humi/p/7979230.html

原创文章,作者:优速盾-小U,如若转载,请注明出处:https://www.cdnb.net/bbs/archives/16716

(0)
上一篇 2022年11月16日 22:30
下一篇 2022年11月16日 22:31

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注

优速盾注册领取大礼包www.cdnb.net
/sitemap.xml