CF 优选,简单来说,就是用一个在 Cloudflare 上配置好的域名(B),来给另一个我们自己的主域名(A)借道加速,尤其是显著提升中国大陆的访问速度
角色介绍
为了方便理解,我们先给今天的主角们分配好角色:
- **主域名 (A)**:8888.com
- 这是访客真正访问的域名,我们希望它能享受到 Cloudflare 的服务。
- 重要:它的 DNS 解析在别的平台管理(比如阿里云、腾讯云、GoDaddy 等),不是在 Cloudflare。
- **回源域名 (B)**:9999.xyz
- 这是我们的“工具域名”,它在 Cloudflare 上进行全部配置,充当一个中间桥梁。
- 它本身不重要,访客也看不到它。
- 你的服务器 IP:1.2.3.4 (这里用一个假的 IP 地址举例)
- 这是你网站内容真正存放的地方。
我们的目标:当用户访问 8888.com 时,实际流量会通过 9999.xyz 在 Cloudflare 上的配置,最终安全地访问到你的服务器。
操作开始:一共六个步骤
第一步:配置“回源域名” (9999.xyz)
首先,我们要把我们的“工具域名”9999.xyz 配置好。
- 登录你的 Cloudflare 账号。
- 进入域名 9999.xyz 的管理后台。
- 点击左侧的 “DNS” -> “Records”。
- 添加一条 A 记录,指向你的真实服务器 IP。
- 类型 (Type): A
- 名称 (Name): origin (你可以自定义,但用 origin 比较清晰)
- IPv4 地址 (Content): 1.2.3.4 (换成你自己的服务器 IP)
- 代理状态 (Proxy status): 务必点亮那朵橙色的小黄云! 这代表流量会经过 Cloudflare。
现在,访问 origin.9999.xyz 就应该能看到你服务器上的网站内容了,并且是经过 Cloudflare 加速的。
第二步:设置“回退源” (Fallback Origin)
这一步是为了让 Cloudflare 知道,当收到访问 9999.xyz 的请求时,应该去哪里找内容。
- 在 9999.xyz 的管理后台,点击左侧的 “SSL/TLS” -> “自定义主机名”。
- 向下滑动,找到 “回退源 (Fallback Origin)” 部分。
- 点击 “添加回退源 (Add Fallback Origin)”。
- 在输入框里填入我们上一步创建的子域名:origin.9999.xyz。
- 点击保存。
保存成功后,状态应该是**有效 (Active)**。
第三步:添加“自定义主机名” (Custom Hostname)
这是最关键的一步!我们要告诉 Cloudflare:“我授权你用 9999.xyz 的配置来服务 8888.com 这个域名。”
- 在 9999.xyz 的管理后台,继续停留在 “SSL/TLS” -> “自定义主机名 (Custom Hostnames)” 标签页。
- 点击 “添加自定义主机名 (Add Custom Hostname)”。
- 在弹出的窗口中,输入我们的主域名:8888.com。
- 其他设置保持默认,点击右下角的 “添加自定义主机名” 按钮。
完成后,Cloudflare 会开始处理,但此时状态会是“待验证 (Pending Validation)”。它需要你证明 8888.com 确实是你的。
第四步:验证“主域名”的所有权
Cloudflare 会给你一条 TXT 记录,你需要把它添加到 8888.com 的 DNS 解析记录里。
- 在刚才的“自定义主机名”页面,你会看到 8888.com 旁边有“查看验证 TXT”之类的链接,点开它。
- 你会得到两条 TXT 记录,一条用于域名所有权验证,一条用于证书验证。记下它们的**主机名 (Name)和值 (Value)**。
- 登录 8888.com 的 DNS 管理平台(比如阿里云、腾讯云等)。
- 添加那两条 TXT 记录。
- 主机记录: 复制 Cloudflare 提供的 Name。
- 记录类型: TXT
- 记录值: 复制 Cloudflare 提供的 Value。
- 添加完成后,回到 Cloudflare 页面,耐心等待几分钟到几小时(DNS 生效需要时间)。
当你看到 8888.com 的主机名状态和证书状态都显示为 ✅ 有效 (Active) 时,就说明验证成功了!
第五步:将“主域名”指向 Cloudflare
万事俱备,只欠东风!现在我们要让 8888.com 指向我们刚刚在 Cloudflare 搭建好的“桥梁”。
- 再次回到 8888.com 的 DNS 管理平台。
- 找到主域名的解析记录(通常是 @ 或者 8888.com 本身)。
- 修改或添加一条 CNAME 记录。
- 主机记录: @ (或者 www,取决于你想让哪个生效)
- 记录类型: CNAME
- 记录值: origin.9999.xyz
💡 优选技巧: 为了获得国内更快的速度,你可以不直接 CNAME 到 origin.9999.xyz,而是使用 优选 CNAME 地址 或者 A 记录。这些地址可以帮助你连接到速度更快的 Cloudflare 节点。 你可以在一些第三方优选工具网站上找到这些地址。找到一个适合你网络的 CNAME 地址,然后把上面的记录值换成这个优选的 CNAME 地址。
第六步:大功告成,最终检查!
现在,所有的配置都完成了!
等待几分钟让 DNS 解析在全球生效后,在浏览器里输入 https://8888.com。
你会发现,打开的网站和你直接访问 origin.9999.xyz 或者你的服务器 IP 所看到的网站一模一样,但此时 8888.com 已经成功套上了 Cloudflare 的 CDN 加速和安全防护!
背后发生了什么?
当你完成所有设置后,一个访客(比如小明)打开网站的奇妙旅程是这样的:
第 1 步:用户访问主域名小明在浏览器里兴冲冲地输入 https://8888.com,然后按下回车。
第 2 步:DNS 指路小明的电脑向 DNS 系统发出询问:“8888.com 的服务器在哪?”8888.com 的 DNS 解析服务(在阿里云/腾讯云等平台)回应说:“我这没直接地址,但你去找 origin.9999.xyz(优选地址) 就行了,它知道在哪。” (这就是我们设置的 CNAME 记录在起作用)
第 3 步:找到 Cloudflare 的加速节点小明的电脑继续问:“那 origin.9999.xyz 在哪?” 这次,Cloudflare 的 DNS 系统接管了。它会智能地分析小明的位置,并告诉他一个离他最近、访问速度最快的 Cloudflare 加速节点服务器的 IP 地址。 (如果你用了优选 CNAME,这里会分配到更适合国内网络的节点!)
第 4 步:连接到“接待员”小明的浏览器连接到这个近在咫尺的 Cloudflare 加速节点,并递上“名片”说:“你好,我是来访问 8888.com 网站的。”
第 5 步:Cloudflare 核对身份并服务Cloudflare 加速节点(我们的“接待员”)收到请求后,立刻查看自己的“贵宾名单”(我们设置的“自定义主机名”)。 它发现 8888.com 确实是授权过的贵宾,于是开始为它提供服务。
第 6 步:智能中转与缓存 (配置与 9999.xyz 保持一致)
- 如果节点有缓存:接待员发现自己手上正好有 8888.com 的网页内容备份,就直接把内容发给小明。(速度飞快,网站秒开!)
- 如果节点没缓存:接待员会通过 Cloudflare 的内部高速专线,去联系我们远在海外的真实服务器(IP: 1.2.3.4),抓取最新的网页内容。这个过程比普通访问快得多也稳定得多。
第 7 步:内容安全送达Cloudflare 节点把从服务器取来的新鲜内容,或者它自己的缓存,安全地交给小明的浏览器。
小明输入 8888.com → 浏览器问 DNS → DNS 通过解析 优选地址 (一个优选的高速 CNAME 或 IP),最终为小明挑选出 Cloudflare 节点 IP → 浏览器连接这个高速节点 IP 并说:“我要 8888.com” → Cloudflare 节点核对“贵宾名单”,确认 8888.com 已被授权(自定义主机名) → 节点于是套用 9999.xyz 的全套服务(缓存、安全规则等)来处理请求 → 节点根据这些规则,检查缓存或去真实服务器取回内容 → 内容安全返回给小明 → 小明成功看到网站
最终,小明愉快地看到了 8888.com 的网站,全程体验如丝般顺滑。他完全不知道自己的访问请求已经进行了一次“全球旅行”,而我们的真实服务器 IP 也被完美地隐藏了起来,非常安全😋
如何处理多个子域名服务?
如果 8888.com 旗下还有 blog.8888.com 和 shop.8888.com 等多个子域名,它们该如何一同享受加速服务?
第一步:为所有子域名添加“自定义主机名”
首先,需要在 9999.xyz 的 “自定义主机名” 列表里,将每一个需要加速的子域名都添加进去并完成所有权验证。
例如,列表中应包含:
- 8888.com
- blog.8888.com
- shop.8888.com
第二步:理解“回退源”的唯一性限制
这里的关键在于!Cloudflare 允许添加多个“自定义主机名”,但 “回退源 (Fallback Origin)” 只能设置一个。
这意味着,无论访客的请求是发往 blog.8888.com 还是 shop.8888.com,Cloudflare 最终都会将所有流量转发到同一个“总出口”——即教程中设置的 origin.9999.xyz,也就是那台作为回源的主服务器(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.8888.com;
location / {
# 直接转发到博客服务器的 8080 端口
proxy_pass http://10.0.0.2:8080;
proxy_set_header Host $host;
# ... 其他 header 设置 ...
}
}
方法 B:SSH 反向隧道代理 (Advanced & Secure)
这种方法适用于后端服务器无法被主服务器直接访问(例如后端在内网 NAT 之后)或需要极高安全性的场景。它通过建立一个加密的 SSH 隧道来传输数据。
工作原理: 由后端服务器主动连接主服务器,并在主服务器上“开一个口”,Nginx 只需将流量送到这个本地的“口”即可。
操作步骤:
- 在后端服务器上建立隧道:登录后端博客服务器 (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.8888.com 的流量转发给自己的 9001 端口即可。Nginx 配置示例:
# 处理博客子域名的流量 (通过 SSH 隧道) server { listen 80; server_name blog.8888.com; location / { # 转发到本地 SSH 隧道的入口端口 proxy_pass http://localhost:9001; proxy_set_header Host $host; # ... 其他 header 设置 ... } }
PS无论使用哪种方法,所有子域名的流量都会经过 Nginx 主服务器。因此,务必确保这台服务器拥有足够大的带宽,以防成为性能瓶颈。