背景说明:

XX全球版项目CDN,

原有改之前:主CDN为Akamai,备CDN为Cloudflare。

计划改之后:主CDN为Cloudflare,备CDN为Akamai。

原因:Akamai CDN的流量成本大概是3毛多1GB是比较贵的,比Cloudflare贵很多,故现在为了节省成本,经领导同意,计划将主CDN切为Cloudfalre,备的CDN切为Akamai。从Akamai切为Cloudflare其CDN成本可以节约一半左右的费用。

注意:文档中项目敏感信息已打码。文档中所有域名使用:www.baidu.com代替

感谢辉哥提供的资料

 

参考文档

# Cloudflare CDN相关api的文档:
​​​https://api.cloudflare.com/#getting-started-requests​​ ​​https://api.cloudflare.com/#zone-purge-all-files​​ ​​https://api.cloudflare.com/#zone-purge-files-by-url​​ ​​https://api.cloudflare.com/#zone-purge-files-by-cache-tags,-host-or-prefix​

     

1.上传或创建SSL域名证书到Cloudflare

  注:如果上传的是自有证书,要注意域名证书的有效期,在到期之前要及时续期并上传新的续期后的域名证书到Cloudflare。

创建Cloudflare CDN_json

创建Cloudflare CDN_json_02

 

创建Cloudflare CDN_json_03

 

2.创建Cloudflare CDN

创建Cloudflare CDN_上传_04

  

创建Cloudflare CDN_json_05

创建Cloudflare CDN_json_05

 

创建Cloudflare CDN_域名解析_07

创建Cloudflare CDN_json_08

创建Cloudflare CDN_域名解析_09

创建Cloudflare CDN_域名解析_10

 

3.测试Cloudflare CDN

  正常如上创建完成了,接着就可以进行测试和域名解析了。

1、测试获取绑定的随机Cloudflare CDN边缘IP
注:Cloudflare边缘CDN为以.cdn.cloudflare.net 结尾,所以如下 dig时要加上 .cdn.cloudflare.net
[root@wyh-test ~]# dig www.baidu.com.cdn.cloudflare.net +short
xx.18.9.27
xx.18.8.27

2、测试http、 https
#–resolve 参数后的 IP 填写上条命令获取的任意一个边缘ip即可
[root@wyh-test ~]#
#测试 http 80
curl http://www.baidu.com/HotfixAssets/test/test9.log --resolve www.baidu.com:80:xx.18.9.27 -svo /dev/null

#测试 https 443
[root@wyh-test ~]#
curl https://www.baidu.com/HotfixAssets/test/test9.log --resolve www.baidu.com:443:xx.18.9.27 -svo /dev/null

创建Cloudflare CDN_域名解析_11

创建Cloudflare CDN_域名解析_12

创建Cloudflare CDN_上传_13

 

4.配置域名解析到Cloudflare CDN's CNAME

  通过CNAME记录将流量指向Cloudflare CDN,具体操作如下:

  登陆域名解析网站(比如AWS域名解析,阿里云解析,腾讯云域名解析网站等,根据实际的来),这里域名​​baidu.com​​是AWS S3域名解析。

  则登录AWS S3域名解析,将​​www.baidu.com​​​解析改为CNAME类型,值为​​www.baidu.com.​​​​cdn.cloudflare.net​​。

 

5.Cloudflare API进行Cloudflare CDN自动刷新

  首先,要获取API授权,具体见:​​通过Cloudflare API进行CDN刷新​

  自动或者手动刷新根据自己实际情况选择。(脚本的实现只是提供一个思路,要根据实际项目情况的目录来更改)

 

5.1 配置腾讯云云函数调用API自动刷新

 

5.2 配置脚本调用API来刷新

  万一云函数自动刷新有问题,可以使用此脚本方法进行刷新。

1.    [root@xx ~]# cat /data/infra/scripts/cloudflare_cdn_refresh_dir.py
2. # -*- coding: UTF-8 -*-
3. # version: by san at 20201202
4. # cloudflare refresh api
5. import json
6. import requests
7. import sys
8. import copy
9.
10. # 针对目录刷新函数
11. def send_msg_dir(api, url):
12. headers = {'Content-Type': 'application/json; charset=utf-8','X-Auth-Email': 'xx@qq.jp', 'X-Auth-Key': '自己的密钥'}
13. data = {
14. "prefixes": url
15. }
16. r = requests.post(api, data=json.dumps(data), headers=headers)
17. return r.text
18.
19. # 针对文件刷新函数
20. def send_msg_url(api, url):
21. headers = {'Content-Type': 'application/json; charset=utf-8','X-Auth-Email': ' xx@qq.jp', 'X-Auth-Key': '自己的密钥'}
22. data = {
23. "files": url
24. }
25. r = requests.post(api, data=json.dumps(data), headers=headers)
26. return r.text
27.
28. if __name__ == '__main__':
29. #url_dir = ["www.baidu.com/HotfixAssets/Global_OBT"]
30. url_dir = ["www.baidu.com/HotfixAssets/Global_7.0"]
31. url_file = copy.deepcopy(url_dir)
32. url_file[0] = "https://" + url_file[0]
33. mversion=sys.argv[1]
34. version=sys.argv[2]
35. ios=sys.argv[3]
36. number=sys.argv[4]
37. url_dir[0] = url_dir[0] + "/" + mversion + "." + version + "/" + ios + "/" + number
38. url_file[0] = url_file[0] + "/" + mversion + "." + version + "/" + ios + "/" + "PkgVersion.json"
39. print(type(url_dir),url_dir,type(url_file),url_file)
40. api = 'https://api.cloudflare.com/client/v4/zones/2869a40871835d9e79a96b89354be1c3/purge_cache'
41. print(send_msg_url(api, url_file))
42. print(send_msg_dir(api, url_dir)

 

6.注意事项

  1.实际是一定要先创建一个测试的Cloudflare CDN域名 ​​www-test.baidu.com​​,测试没问题,然后再进行如上步骤的操作。

  2.如果上传的是自有证书,要注意域名证书的有效期,在到期之前要及时续期并上传新的续期后的域名证书到Cloudflare。

作者:​​小家电维修​

转世燕还故榻,为你衔来二月的花。