type
status
date
slug
summary
tags
category
icon
password

Cloudflare Zero Trust:Cloudflare Tunnel使用教程

cf tunnel 是什么?

Cloudflare Tunnel为您提供了一种安全的方式,将您的资源连接到Cloudflare,而无需公共可路由的IP地址。使用Tunnel,您不会将流量发送到外部IP地址,而是在您的基础设施中创建一个轻量级的守护程序,仅向Cloudflare的全球网络创建出站连接。Cloudflare Tunnel可以安全地将HTTP Web服务器、SSH服务器、远程桌面和其他协议连接到Cloudflare。这样,您的源站可以通过Cloudflare提供流量,而不会容易受到绕过Cloudflare的攻击。
(摘自官方文档)

有什么用?

tunnel字面意思一根加密隧道直接从Cloudflare网络插到你的服务器,提供webui页面方便管理域名与服务器上部署的项目之间的绑定。
  • 项目部署上线更简单,只需建立好隧道,然后设置域名指向项目暴露的本地地址和端口即可。
  • 无需编写任何 Nginx 配置,非常适合像我这样的懒人或小白用户。
  • 无需配置证书,使用加密隧道,项目不会直接暴露到公网上,从而增强了安全性。(ps: 需开启防火墙)

如何工作的?

大致流程为:
用户 —> cf服务器 —> cf侧tunnel设置入口 --(加密)–> 服务器侧的tunnel出口 → 本机项目

开始搭建

1. 在Cloudflare的侧边栏中,找到并点击Zero Trust 菜单。如果是首次使用,需要进行订阅,选择免费套餐进行开通。

2. 在进入Zero Trust面板后,从侧边栏中找到并点击Tunnel 菜单。

3. 创建一条隧道(cf侧)

3.1 隧道类型选Cloudflared
3.2 设置隧道名,名字随便取,我个人习惯于取能够辨识服务器的名称。
3.3 安装环境选Docker,记得复制docker的安装命令以备后用。
3.4 不用点下一步,直接在左上角点击返回,即可确认隧道已成功创建。

4. 服务器侧隧道设置

在第3.3节中,我们获得了一个类似于以下的docker命令:
先别着急用,需要添加几个docker参数,注意network需要设置为host。讲一下我之前遇到的坑,docker启动容器默认会使用桥接模式(bridge),在后面域名绑定时,127.0.0.1:port是cloudflared这个容器内部的地址,如果你的项目也是使用docker的桥接模式启动的,那么就无法找到对应的服务。当然也可以用172.17.0.1:port这个地址进行绑定,但还是建议让cloudflared容器以host模式启动。
docker启动命令
or
docker-compose配置

5. 配置域名和部署项目的绑定

5.1 点击前面创建的隧道Configure
5.2 添加Public Hostname
5.3 配置域名与服务器上的项目端口,类型有很多可选的,选http即可。
5.4 配置完成后,尝试访问你的域名以确认是否设置成功。

本文整理自 https://linux.do/t/topic/3628,如有侵权,请联系删除。
Tailscale DERP Docker版教程最常用的“一键脚本”汇总
Loading...
mozui
mozui
一个普通的干饭人🍚
公告
🌟 博客新篇章 🌟
👁️‍🗨️ 欢迎踏入我的文字殿堂!在这里,每一篇文章都是我心灵的独白,探索世界的深度,分享生活的色彩。
💡 您的每一次点击,都是对我最大的鼓励。在评论区留下您的足迹,让我们共同构建一个思想的交流平台。
感谢您的陪伴,让我们一起在知识的星空中,寻找属于自己的那颗星!
温暖的问候, [抹嘴]