《Windows Azure Platform 系列文章目录

  

  最近处理了很多CDN的问题,在这里记录一下。

  1.首先介绍一下CDN的原理:

  (1)用户输入需要访问的URL (比如www.contoso.cn),经过本地的DNS Server进行解析

  (2)DNS Server返回www.contoso.cn域名对应的CNAME:www.contoso.cn.mschcdn.com

  (3)为了得到实际IP地址,浏览器需要再次对获得的CNAME域名进行解析以得到实际的IP地址

  (4)用户向该IP节点(CDN服务器)发出请求

  (5)全局负载均衡设备把服务器的IP地址返回给用户

  (6)由于是第一次访问,CDN服务器会向原web站点请求,并缓存内容

  (7)请求结果发给用户

  2.国内使用Azure CDN需要准备好:

  (1)用户自己的域名,比如cdn.contoso.cn

  (2)该域名(cdn.contoso.cn) 必须进行过ICP备案,并且有ICP备案编号

  3.Azure支持的CDN加速类型:

  (1)HTTP加速

  (2)HTTPS加速

  4.创建Azure China CDN,如下图所示:

  

  上图中:

  (1)Custom Domain,是用户自己的域名,这里假设为:cdn.contoso.cn

  (2)ICP Number,是用户域名的ICP备案号

  (3)Acceleration Type,是CDN的加速类型。Azure CDN支持的加速类型有

  -Web加速

  -下载加速

  -VOD加速

  -图片处理加速

  针对不同的加速类型,Azure CDN的缓存策略是不同的。我会在后面的内容做项目的介绍

  (4)Origin Domain Type,是源站类型。Azure CDN支持的源站类型有

  -Cloud Service,云服务

  -Storage Account,存储账户

  -Web App,网站服务

  -Media Service,媒体服务

  -Custom origin domain,用户自定义域名。即CDN的源站,可以不在微软云Azure平台,可以在用户自己的IDC环境。

  (5)Origin host header,表示访问CDN的HTTP Host 头

  

  5.我们输入上面的信息并提交后,Azure CDN会验证用户自定义域名和ICP备案是否有效。此时CDN状态为Creating。如下图:

  

  

  6.等待Azure平台验证通过后,上面的Status状态为Ready,同时微软云Azure CDN会提供一个新的二级域名,假设为cdn.contoso.cn.mschcdn.com

  

  7.接下来,我们需要在DNS供应商那边,把自己的域名:cdn.contoso.cn,增加CNAME到,cdn.contoso.cn.mschcdn.com

  8.进入CDN的配置页面,我们点击Manage。如下图:

  

  注意事项1:在弹出的窗口中,如果源站是Web App的话,因为Web App绑定了HOST。所以HOST头必须为Web App的默认域名 (******.chinacloudsites.cn)

  

  注意事项2:当CDN的Header中包含Set-Cookie时,默认是不缓存的。

  如果我们的源站使用Web App的话,Web App默认HTTP Head包含Cookie ARR Affinity。如下图:

  

  我们有两种解决方案(二选一)

  (1)关闭Azure Web App ARR Affnity

  

  (2)或者在CDN缓存规则里,设置忽略Cookie

  

  注意事项3:注意修改默认的缓存规则

  当我们上面介绍了,CDN支持的加速类型有:Web加速,下载加速,VOD加速等

  Web 加速,默认的缓存规则如下:

  

  下载加速,默认的缓存规则如下:

  

  我们需要按照自己的业务需求,设置自己的缓存规则。比如上面的下载加速,默认是不提供png, jpg, gif, jpeg下载的

  我们就需要增加一行缓存内容。如下图:

  

  注意事项4,缓存规则是逐条匹配的

  系统根据配置顺序逐条匹配,最先配置的规则具有最高优先级。规则被匹配后,其后的规则不再被匹配。

  举个例子:

  

  在上图中,虽然我们在缓存内容中,分别匹配了两条规则,分别对应

  -shtml;html;htm

  -png;jpg;gif;jpeg

  但是在不扩展内容中,优先配置了整个根目录,所以后面的缓存内容都无效

  正确的配置应该如下图:

  

  注意事项5:如果我们想主动推动CDN缓存内容,到POP点,可以选择预加载。如下图:

  请注意:预加载只能针对文件操作,无法针对目录操作

  

  

  注意事项6:我们可以通过Chrome,观察Respond Header,来观察是否命中CDN POP点

  首先我们打开Chrome,按F12,选择Network,查看Respond Header X-Cache信息

   如果命中,则如下图:

  

  

  如果没有命中,则参考下图:

  

  注意事项7:如果源站之前有WAF(Web Application Firewall)的情况下,如何配置

  首先我们需要了解数据流向是:客户端->CDN->WAF->源站

  所以CDN的源站信息,指向WAF前端的公网IP地址,HOST根据需要填写。

  如果源站是Azure Web App的话,HOST必须为Web App的默认域名 (******.chinacloudsites.cn)

  最后请WAF的供应商做请求转发即可

Azure China (13) Azure China CDN经验总结的更多相关文章

  1. Windows Azure HandBook (2) Azure China提供的服务

    <Windows Azure Platform 系列文章目录> 对于传统的自建数据中心,从底层的Network,Storage,Servers,Virtualization,中间层的OS, ...

  2. Azure China (2) Azure China管理界面初探

    <Windows Azure Platform 系列文章目录> 首先是Q&A时间 1.我在Azure Global拥有测试账号或者免费的MSDN订阅账号,这个账号可以在国内Azur ...

  3. Windows Azure Active Directory (4) China Azure AD Self Password Reset

    <Windows Azure Platform 系列文章目录> 本文介绍的是国内由世纪互联运维的Azure China. 在开始本章内容之前,请读者熟悉笔者之前写的文档: Windows ...

  4. 使用 Azure CLI 在 Azure China Cloud 云平台上手动部署一套 Cloud Foundry

    这篇文章将介绍如何使用 Azure CLI 在 Azure China Cloud 云平台上手动部署一套 Cloud Foundry.本文的目的在于: 了解作为 PaaS 的 Cloud Foundr ...

  5. [SDK2.2]SQL Azure (13) Azure的两种关系型数据库服务:SQL Azure与SQL Server VM的不同

    <Windows Azure Platform 系列文章目录> 如果熟悉Windows Azure平台的用户不难发现,对于SQL Server数据库来说,微软提供了两种服务,分别是: -W ...

  6. Azure Backup (2) Azure备份服务

    <Windows Azure Platform 系列文章目录> 本文介绍的是国内由世纪互联运维的Azure China. 本文介绍的Azure管理界面是Classic Model,网址:h ...

  7. Microsoft Azure News(5) Azure新DV2系列虚拟机上线

    <Windows Azure Platform 系列文章目录> 在之前的文章中,笔者了Azure VM虚拟机,分为A系列和D系列2种 Microsoft Azure News(4) Azu ...

  8. Windows 上安装 Azure PowerShell及Azure PowerShell部署虚拟机

    一.Azure PowerShell部署   1.使用 PowerShellGet 在 Windows 上安装 Azure PowerShell 从 Azure PowerShell 版本 6.0 开 ...

  9. 如何使用 Azure PowerShell 在 Azure Marketplace 中查找 Windows VM 映像

    本主题介绍如何使用 Azure PowerShell 在 Azure Marketplace 中查找 VM 映像. 创建 Windows VM 时使用此信息来指定 Marketplace 映像. 确保 ...

随机推荐

  1. Python学习笔记第二十五周(Django补充)

    1.render_to_reponse() 不同于render,render_to_response()不用包含request,直接写template中文件 2.locals() 如果views文件中 ...

  2. Mysql安装和基本使用

    MySQL的介绍安装.启动 windows上制作服务 MySQL破解密码 MySQL中统一字符编码 MySQL MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Ora ...

  3. SEGMENTATION FAULT IN LINUX 原因与避免

    https://www.cnblogs.com/no7dw/archive/2013/02/20/2918372.html

  4. Linux用管道命令对文件的移动

    我的问题是这样的:我有一个文件夹,里面有大约有1000个文件,然后我想把这样的一部分文件给随机分成两部分,一部分含有100张,另外一部分含有剩下的所有的文件,这个时候如果是在Linux图形界面的话直接 ...

  5. python调用caffe实现预测

    对于已经训练完成的caffemodel,对于单个的图片预测,用python接口来调用是一件非常方便的事情,下面就来讲述如何用python调用已经训练完成的caffemodel,以及prototxt,网 ...

  6. tarfile — Read and write tar archive files

    参考: https://docs.python.org/2/library/tarfile.html http://www.jianshu.com/p/bbad16822eab #解压文件tarfil ...

  7. JAVA基础部分复习(五、JAVA反射)

    关于反射: 1.需要了解jvm类的加载机制(java高级部分会详细介绍) 2.反射的API其实只要多看看API和源码,很容易就懂了. 下面是代码,简单讲解反射的使用: import java.lang ...

  8. NHibernate many-to-one映射

    many-to-one 数据方面,多条对一条. 非主键字段与主键字段的关联,在类中实现了一对一的单向映射.在类中是单实体映射. 订单充值业务.显然,一单位可以有多个充值信息. 通过表 Deposit里 ...

  9. vue拓展题

    本文档基于vue-cli技术栈总结了 vue-cli工程 vue.js核心知识 vue-router路由 vuex状态管理器 axios等http请求 移动端适配 Tab切换等常用功能 vue与原生a ...

  10. DES算法,JAVA,遇到的问题

    (1)使用Based64编码时出现的问题. java.lang.IllegalArgumentException 这中情况出现在解密时,主要原因是based64加密时用了sun的内部包sun.misc ...