Azure China (13) Azure China CDN经验总结
《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经验总结的更多相关文章
- Windows Azure HandBook (2) Azure China提供的服务
<Windows Azure Platform 系列文章目录> 对于传统的自建数据中心,从底层的Network,Storage,Servers,Virtualization,中间层的OS, ...
- Azure China (2) Azure China管理界面初探
<Windows Azure Platform 系列文章目录> 首先是Q&A时间 1.我在Azure Global拥有测试账号或者免费的MSDN订阅账号,这个账号可以在国内Azur ...
- Windows Azure Active Directory (4) China Azure AD Self Password Reset
<Windows Azure Platform 系列文章目录> 本文介绍的是国内由世纪互联运维的Azure China. 在开始本章内容之前,请读者熟悉笔者之前写的文档: Windows ...
- 使用 Azure CLI 在 Azure China Cloud 云平台上手动部署一套 Cloud Foundry
这篇文章将介绍如何使用 Azure CLI 在 Azure China Cloud 云平台上手动部署一套 Cloud Foundry.本文的目的在于: 了解作为 PaaS 的 Cloud Foundr ...
- [SDK2.2]SQL Azure (13) Azure的两种关系型数据库服务:SQL Azure与SQL Server VM的不同
<Windows Azure Platform 系列文章目录> 如果熟悉Windows Azure平台的用户不难发现,对于SQL Server数据库来说,微软提供了两种服务,分别是: -W ...
- Azure Backup (2) Azure备份服务
<Windows Azure Platform 系列文章目录> 本文介绍的是国内由世纪互联运维的Azure China. 本文介绍的Azure管理界面是Classic Model,网址:h ...
- Microsoft Azure News(5) Azure新DV2系列虚拟机上线
<Windows Azure Platform 系列文章目录> 在之前的文章中,笔者了Azure VM虚拟机,分为A系列和D系列2种 Microsoft Azure News(4) Azu ...
- Windows 上安装 Azure PowerShell及Azure PowerShell部署虚拟机
一.Azure PowerShell部署 1.使用 PowerShellGet 在 Windows 上安装 Azure PowerShell 从 Azure PowerShell 版本 6.0 开 ...
- 如何使用 Azure PowerShell 在 Azure Marketplace 中查找 Windows VM 映像
本主题介绍如何使用 Azure PowerShell 在 Azure Marketplace 中查找 VM 映像. 创建 Windows VM 时使用此信息来指定 Marketplace 映像. 确保 ...
随机推荐
- 机器学习:Kullback-Leibler Divergence (KL 散度)
今天,我们介绍机器学习里非常常用的一个概念,KL 散度,这是一个用来衡量两个概率分布的相似性的一个度量指标.我们知道,现实世界里的任何观察都可以看成表示成信息和数据,一般来说,我们无法获取数据的总体, ...
- BT觀念分享和常見問題彙整
一. TCP/IP基本觀念 1. IP : 每台在TCP/IP網路上的電腦必須具備的一個代表號或一個地址.IP又分為private IP(192.168.x.x /10.x.x.x /172.16.x ...
- Python之路,第十六篇:Python入门与基础16
python3 bytes 和 bytearrary bytes 二进制文件的读写: 什么是二进制文件读: 文件中以字节(byte)为单位存储,不以换行符(\n)为单位分隔内容的文件: f = o ...
- WCF 添加服务引用 HTTP 请求已超过为 00:00:00 分配的超时。为此操作分配的时间可能是较长超时
今天在用公司的笔记本引用WCF的时候,处于一直等待的过程,一直在下载信息,一直等了很长时间,弹出了一个消息 下载“http://ip:8085/xxxxx/xxxxx/mex/$metadata”时出 ...
- Linux系统下curl命令上传文件,文件名包含逗号无法上传
使用curl命令,将备份好的图片全部重新导入到seaweedfs,图片全部以存储在seaweedfs中的fid命令, fid中间有一个逗号,使用curl命令时报错: curl: (26) couldn ...
- python三大框架之一flask中cookie和session的相关操作
状态保持 Cookie cookie 是指某些网站为了 辨别 用户身份,进行会话跟踪而储存在用户本地的数据(通常会经过加密),复数形式是 coolies. cookie是由服务器端生成,发送给客户端 ...
- Washing Text Animation
https://www.youtube.com/watch?v=q0_koJLc0OgBlender Tutorial: Washing Text Animation 需要用到插件, 进入用户设置的插 ...
- MATLAB中版本和日期函数
本博客中输出版本号和日期的子函数,今天才发现忘记上代码了,这里补上 function banner() %% --------------------------------------------- ...
- Spring 注解bean默认名称规则
在使用@Component.@Repository.@Service.@Controller等注解创建bean时,如果不指定bean名称,bean名称的默认规则是类名的首字母小写,如SysConfig ...
- linux系统常用监控系统状态信息命令
[root@bogon ~]# uptime #平均负载 23:33:21 up 2:09, 3 users, load average: 0.02, 0.05, 0.05 [root@bogon ~ ...