Cloudflare 中国大陆访问加速指南:SaaS回源优选配置详解

如何利用优选域名及节点,为外部托管域名平滑添加 Cloudflare CDN 与全球网络优化,涵盖多子域名处理、Nginx 反向代理与 SSH 隧道等进阶方案,适合站长和运维人员收藏使用。

CF优选,简单来说,就是用一个在 Cloudflare 上配置好的域名(B),来给另一个我们自己的主域名(A)借道加速,尤其是显著提升中国大陆的访问速度

Cloudflare 中国大陆访问加速指南:SaaS回源优选配置详解

角色介绍

为了方便理解,我们先给今天的主角们分配好角色:

  1. **主域名 (A)**:leepoet.cn
  • 这是访客真正访问的域名,我们希望它能享受到 Cloudflare 的服务。
  • 重要:它的 DNS 解析在别的平台管理(比如阿里云、腾讯云、GoDaddy 等),不是在 Cloudflare。
  • **回源域名 (B)**:leepoet.com
  • 这是我们的“工具域名”,它在 Cloudflare 上进行全部配置,充当一个中间桥梁。
  • 它本身不重要,访客也看不到它。
  • 你的服务器 IP1.2.3.4 (这里用一个假的 IP 地址举例)
  • 这是你网站内容真正存放的地方。

我们的目标:当用户访问 leepoet.cn 时,实际流量会通过 leepoet.com 在 Cloudflare 上的配置,最终安全地访问到你的服务器。

操作开始:一共六个步骤

第一步:配置“回源域名” (leepoet.com)

首先,我们要把我们的“工具域名”leepoet.com 配置好。

  1. 登录你的 Cloudflare 账号。
  2. 进入域名 leepoet.com 的管理后台。
  3. 点击左侧的 “DNS” -> “Records”。
  4. 添加一条 A 记录,指向你的真实服务器 IP。
  • 类型 (Type)A
  • 名称 (Name)origin (你可以自定义,但用 origin 比较清晰)
  • IPv4 地址 (Content)1.2.3.4 (换成你自己的服务器 IP)
  • 代理状态 (Proxy status)务必点亮那朵橙色的小黄云! 这代表流量会经过 Cloudflare。

现在,访问 origin.leepoet.com 就应该能看到你服务器上的网站内容了,并且是经过 Cloudflare 加速的。

第二步:设置“回退源” (Fallback Origin)

这一步是为了让 Cloudflare 知道,当收到访问 leepoet.com 的请求时,应该去哪里找内容。

  1. 在 leepoet.com 的管理后台,点击左侧的 “SSL/TLS” -> “自定义主机名”。
  2. 向下滑动,找到 “回退源 (Fallback Origin)” 部分。
  3. 点击 “添加回退源 (Add Fallback Origin)”。
  4. 在输入框里填入我们上一步创建的子域名:origin.leepoet.com
  5. 点击保存。

保存成功后,状态应该是**有效 (Active)**。

第三步:添加“自定义主机名” (Custom Hostname)

这是最关键的一步!我们要告诉 Cloudflare:“我授权你用 leepoet.com 的配置来服务 leepoet.cn 这个域名。”

  1. 在 leepoet.com 的管理后台,继续停留在 “SSL/TLS” -> “自定义主机名 (Custom Hostnames)” 标签页。
  2. 点击 “添加自定义主机名 (Add Custom Hostname)”。
  3. 在弹出的窗口中,输入我们的主域名leepoet.cn
  4. 其他设置保持默认,点击右下角的 “添加自定义主机名” 按钮。

完成后,Cloudflare 会开始处理,但此时状态会是“待验证 (Pending Validation)”。它需要你证明 leepoet.cn 确实是你的。

第四步:验证“主域名”的所有权

Cloudflare 会给你一条 TXT 记录,你需要把它添加到 leepoet.cn 的 DNS 解析记录里。

  1. 在刚才的“自定义主机名”页面,你会看到 leepoet.cn 旁边有“查看验证 TXT”之类的链接,点开它。
  2. 你会得到两条 TXT 记录,一条用于域名所有权验证,一条用于证书验证。记下它们的**主机名 (Name)值 (Value)**。
  3. 登录 leepoet.cn 的 DNS 管理平台(比如阿里云、腾讯云等)。
  4. 添加那两条 TXT 记录。
  • 主机记录: 复制 Cloudflare 提供的 Name。
  • 记录类型TXT
  • 记录值: 复制 Cloudflare 提供的 Value。
  • 添加完成后,回到 Cloudflare 页面,耐心等待几分钟到几小时(DNS 生效需要时间)。

当你看到 leepoet.cn 的主机名状态证书状态都显示为 ✅ 有效 (Active) 时,就说明验证成功了!

第五步:将“主域名”指向 Cloudflare

万事俱备,只欠东风!现在我们要让 leepoet.cn 指向我们刚刚在 Cloudflare 搭建好的“桥梁”。

  1. 再次回到 leepoet.cn 的 DNS 管理平台。
  2. 找到主域名的解析记录(通常是 @ 或者 leepoet.cn本身)。
  3. 修改或添加一条 CNAME 记录。
  • 主机记录@ (或者 www,取决于你想让哪个生效)
  • 记录类型CNAME
  • 记录值origin.leepoet.com

💡 优选技巧: 为了获得国内更快的速度,你可以不直接 CNAME 到 origin.leepoet.com,而是使用 优选 CNAME 地址 或者 A 记录。这些地址可以帮助你连接到速度更快的 Cloudflare 节点。 你可以在一些第三方优选工具网站上找到这些地址。找到一个适合你网络的 CNAME 地址,然后把上面的记录值换成这个优选的 CNAME 地址。

第六步:大功告成,最终检查!

现在,所有的配置都完成了!

等待几分钟让 DNS 解析在全球生效后,在浏览器里输入 https://leepoet.cn

你会发现,打开的网站和你直接访问 origin.leepoet.com 或者你的服务器 IP 所看到的网站一模一样,但此时 leepoet.cn已经成功套上了 Cloudflare 的 CDN 加速和安全防护!

背后发生了什么?

当你完成所有设置后,一个访客(比如小明)打开网站的奇妙旅程是这样的:

第 1 步:用户访问主域名小明在浏览器里兴冲冲地输入 https://leepoet.cn,然后按下回车。

第 2 步:DNS 指路小明的电脑向 DNS 系统发出询问:“leepoet.cn 的服务器在哪?”leepoet.cn 的 DNS 解析服务(在阿里云/腾讯云等平台)回应说:“我这没直接地址,但你去找 origin.leepoet.com(优选地址) 就行了,它知道在哪。” (这就是我们设置的 CNAME 记录在起作用)

第 3 步:找到 Cloudflare 的加速节点小明的电脑继续问:“那 origin.leepoet.com 在哪?” 这次,Cloudflare 的 DNS 系统接管了。它会智能地分析小明的位置,并告诉他一个离他最近、访问速度最快的 Cloudflare 加速节点服务器的 IP 地址。 (如果你用了优选 CNAME,这里会分配到更适合国内网络的节点!)

第 4 步:连接到“接待员”小明的浏览器连接到这个近在咫尺的 Cloudflare 加速节点,并递上“名片”说:“你好,我是来访问 leepoet.cn 网站的。”

第 5 步:Cloudflare 核对身份并服务Cloudflare 加速节点(我们的“接待员”)收到请求后,立刻查看自己的“贵宾名单”(我们设置的“自定义主机名”)。 它发现 leepoet.cn确实是授权过的贵宾,于是开始为它提供服务。

第 6 步:智能中转与缓存 (配置与leepoet.com保持一致)

  • 如果节点有缓存:接待员发现自己手上正好有 leepoet.cn的网页内容备份,就直接把内容发给小明。(速度飞快,网站秒开!)
  • 如果节点没缓存:接待员会通过 Cloudflare 的内部高速专线,去联系我们远在海外的真实服务器(IP: 1.2.3.4),抓取最新的网页内容。这个过程比普通访问快得多也稳定得多。

第 7 步:内容安全送达Cloudflare 节点把从服务器取来的新鲜内容,或者它自己的缓存,安全地交给小明的浏览器。

小明输入 leepoet.cn → 浏览器问DNS → DNS通过解析 优选地址 (一个优选的高速CNAME或IP),最终为小明挑选出Cloudflare节点IP → 浏览器连接这个高速节点IP并说:“我要 leepoet.cn” → Cloudflare节点核对“贵宾名单”,确认 leepoet.cn 已被授权(自定义主机名) → 节点于是套用 leepoet.com 的全套服务(缓存、安全规则等)来处理请求 → 节点根据这些规则,检查缓存或去真实服务器取回内容 → 内容安全返回给小明 → 小明成功看到网站

最终,小明愉快地看到了 leepoet.cn 的网站,全程体验如丝般顺滑。他完全不知道自己的访问请求已经进行了一次“全球旅行”,而我们的真实服务器 IP 也被完美地隐藏了起来,非常安全😋

如何处理多个子域名服务?

如果 leepoet.cn 旗下还有 blog.leepoet.cn 和 shop.leepoet.cn 等多个子域名,它们该如何一同享受加速服务?

第一步:为所有子域名添加“自定义主机名”

首先,需要在 leepoet.com 的 “自定义主机名” 列表里,将每一个需要加速的子域名都添加进去并完成所有权验证。

例如,列表中应包含:

  • leepoet.cn
  • blog.leepoet.cn
  • shop.leepoet.cn

第二步:理解“回退源”的唯一性限制

这里的关键在于!Cloudflare 允许添加多个“自定义主机名”,但 “回退源 (Fallback Origin)” 只能设置一个

这意味着,无论访客的请求是发往 blog.leepoet.cn 还是 shop.leepoet.cn,Cloudflare 最终都会将所有流量转发到同一个“总出口”——即教程中设置的 origin.leepoet.com,也就是那台作为回源的主服务器(IP: 1.2.3.4)。

第三步:解决方案,引入 Nginx 作为中央反向代理

既然所有子域名的流量都汇集到了同一台主服务器,就需要在这台服务器上部署一个“智能交通指挥官”来根据域名分发流量。这个角色最适合由 Nginx 担任。

Nginx 会检查每个请求的目标域名,然后将其转发到正确的后端服务器。连接后端服务器主要有两种方式:

实战来咯,后端流量转发的两种方法

方法 A:标准反向代理 (Direct Proxy_Pass)

这是最直接、最常见的方法,适用于主服务器和后端服务器之间网络通畅(例如在同一内网或公网可直接访问)的情况。

操作:在主服务器 (1.2.3.4) 的 Nginx 配置文件中,通过 proxy_pass 直接指向后端服务器的 IP 和端口。

Nginx 配置示例:

# 处理博客子域名的流量
server {
    listen 80;
    server_name blog.leepoet.cn;

    location / {
        # 直接转发到博客服务器的 8080 端口
        proxy_pass http://10.0.0.2:8080; 
        proxy_set_header Host $host;
        # ... 其他 header 设置 ...
    }
}

方法 B:SSH 反向隧道代理 (Advanced & Secure)

这种方法适用于后端服务器无法被主服务器直接访问(例如后端在内网 NAT 之后)或需要极高安全性的场景。它通过建立一个加密的 SSH 隧道来传输数据。

工作原理: 由后端服务器主动连接主服务器,并在主服务器上“开一个口”,Nginx 只需将流量送到这个本地的“口”即可。

操作步骤:

  1. 在后端服务器上建立隧道:登录后端博客服务器 (10.0.0.2),执行以下命令,与主服务器 (1.2.3.4) 建立连接。 # 命令格式:ssh -fN -R [主服务器端口]:localhost:[后端服务端口] [主服务器用户名]@[主服务器IP]
    ssh -fN -R 9001:localhost:8080 user@1.2.3.4
  • -fN: 让 SSH 在后台运行。
  • -R 9001:localhost:8080: 意思是将主服务器 (1.2.3.4) 的 9001 端口收到的所有流量,通过这条加密隧道,转发到当前后端服务器 (10.0.0.2) 的 8080 端口。
  • 提示: 为保证隧道断开后能自动重连,建议使用 autossh 工具。
  • 在主服务器上配置 Nginx:现在,主服务器上的 Nginx 只需将 blog.leepoet.cn 的流量转发给自己的 9001 端口即可。 Nginx 配置示例: # 处理博客子域名的流量 (通过 SSH 隧道)
    server {
        listen 80;
        server_name blog.leepoet.cn;

        location / {
            # 转发到本地 SSH 隧道的入口端口
            proxy_pass http://localhost:9001; 
            proxy_set_header Host $host;
            # ... 其他 header 设置 ...
        }
    }

PS无论使用哪种方法,所有子域名的流量都会经过 Nginx 主服务器。因此,务必确保这台服务器拥有足够大的带宽,以防成为性能瓶颈。