《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. java网络编程ServerSocket类 和Socket类的常用构造方法及其方法

    Socket类Socket(InetAddress address, int port) 创建一个流套接字并将其连接到指定 IP 地址的指定端口号.Socket(String host, int po ...

  2. RAC环境修改参数生效测试

    本篇文档--目的:实验测试在RAC环境下,修改数据库参数与单实例相比,需要注意的地方 --举例说明,在实际生产环境下,以下参数很可能会需要修改 --在安装数据库完成后,很可能没有标准化,初始化文档,没 ...

  3. Python中的filter()函数的用法

    转载自:脚本之家 Python内建的filter()函数用于过滤序列. 和map()类似,filter()也接收一个函数和一个序列.和map()不同的时,filter()把传入的函数依次作用于每个元素 ...

  4. hdoj-1068(二分图的最小点覆盖)

    题目 1  问题转化: 求二分图最小点覆盖(覆盖所有的边) 2  问题的解决: 二分图最小点覆盖==其最大匹配数 3   证明: 链接 =#include <bits/stdc++.h> ...

  5. CentOS7安装PostgreSQL10,pgadmin4

    ======PostgreSQL10 CentOS7=================FYI:https://tecadmin.net/install-postgresql-server-centos ...

  6. L2-008 最长对称子串 (25 分)

    对给定的字符串,本题要求你输出最长对称子串的长度.例如,给定Is PAT&TAP symmetric?,最长对称子串为s PAT&TAP s,于是你应该输出11. 输入格式: 输入在一 ...

  7. url中携带中文乱码问题

    1.问题描述 在项目中碰见url中经常传递中文参数时,容易出现乱码问题,现在就这个问题产生原因和解决的措施大概分析一下,希望过路人和我能引以为戒. 2.问题分析 由于我们利用URL传递参数这种方式是依 ...

  8. java.lang.IllegalArgumentException: An invalid domain [.test.com] was specified for this cookie

    https://blog.csdn.net/cml_blog/article/details/52135115 当项目中使用单点登录功能时,通常会使用cookie进行信息的保存,这样就可以在多个子域名 ...

  9. Go Example--结构体

    package main import "fmt" //定义一个私有结构体 type person struct { name string age int } func main ...

  10. ios-密码加密

    加密文件可到网上搜索MyMD5后下载 MyMD5.h文件 // // MyMD5.h // GoodLectures // // Created by yangshangqing on 11-10-1 ...