在 Ubuntu 下通过 Docker 部署 Cloudflared Tunnel 服务器

Cloudflared 是 Cloudflare 提供的一个命令行工具,用于创建安全的隧道,连接本地服务器与 Cloudflare 的网络。通过 Cloudflared Tunnel,可以轻松实现安全的远程访问,保护应用程序和服务免受 DDoS 攻击。Docker 则是一个强大的容器化平台,能够快速打包和运行应用程序,使得部署和管理变得更加简单和高效。

一、使用到的 Docker 和 Cloudflared Tunnel 软件简介

  • Docker:Docker 是一种开源的应用容器引擎,允许开发者将应用及其依赖打包成一个标准化的容器。容器可以在任何支持 Docker 的环境中运行,保证了环境的一致性和可移植性。

  • Cloudflared:Cloudflared 是用来与 Cloudflare 网络进行交互的工具,主要用于创建安全的隧道,支持 HTTP(S) 服务的快速部署和访问。它使得开发者能够轻松连接到 Cloudflare 的边缘网络,实现安全且高效的网络访问。

二、在 Ubuntu 下通过 Docker 部署 Cloudflared Tunnel 服务器的步骤

步骤 1:安装 Docker

首先,确保你的 Ubuntu 系统上安装了 Docker。可以使用以下命令进行安装:

sudo apt update
sudo apt install docker.io

安装完成后,启动 Docker 并设置为开机自启:

sudo systemctl start docker
sudo systemctl enable docker

步骤 2:创建 Cloudflare Tunnel

在使用 Cloudflared 之前,首先需要在 Cloudflare 中创建一个 Tunnel。使用以下命令登录 Cloudflare:

docker run -it --rm \
  cloudflare/cloudflared:latest login

这会打开浏览器,要求你登录 Cloudflare 账户并授权。

步骤 3:运行 Cloudflared Tunnel

创建 Tunnel 后,使用以下命令启动 Cloudflared:

docker run -d \
  --name cloudflared \
  -v /path/to/your/config:/etc/cloudflared \
  cloudflare/cloudflared:latest tunnel run

步骤 4:配置文件

/path/to/your/config 目录下,创建一个名为 config.yml 的配置文件,内容如下:

tunnel: <YOUR_TUNNEL_ID>
credentials-file: /etc/cloudflared/<YOUR_TUNNEL_ID>.json

ingress:
  - hostname: example.com
    service: http://localhost:8080
  - service: http_status:404

参数解释

  • -d:后台运行容器。
  • --name:指定容器名称。
  • -v:将主机目录挂载到容器内,便于访问配置文件。
  • tunnel:你的 Cloudflare Tunnel ID。
  • credentials-file:Tunnel 的凭证文件路径。
  • ingress:配置隧道的访问规则,包括主机名和对应的服务。

步骤 5:访问服务

一切配置完成后,通过 Cloudflare 访问你的服务,例如 https://example.com

小结

通过以上步骤,你已经成功在 Ubuntu 上通过 Docker 部署了 Cloudflared Tunnel 服务器。现在可以轻松实现安全的远程访问,保护你的应用程序了。别忘了定期检查和更新配置,确保安全性。

### 使用 Docker 安装和配置 Cloudflare 相关服务 #### 启动并配置 Docker 环境 为了确保 Docker 已经正确安装并且能够自动启动,在 Ubuntu 中可以执行如下命令来开启 Docker 服务以及设定其随系统启动而运行: ```bash sudo systemctl start docker sudo systemctl enable docker ``` #### 创建 Cloudflare Tunnel 对于希望通过 Docker部署 Cloudflared Tunnel 的情况,按照官方指导完成必要的操作即可[^1]。 #### 设置私有 Docker 镜像仓库加速器 如果目标是利用 Cloudflare 构建个人专属的 Docker 镜像源,则需先调整 `/etc/docker/daemon.json` 文件中的 `registry-mirrors` 参数指向自定义地址。当该文件不存在时应手动创建它,并加入相应的 JSON 数据结构指定镜像源URL。之后记得重启 Docker 使更改生效: ```json { "registry-mirrors": [ "https://xxx.域名.com" ] } ``` 接着通过下面这条指令让修改后的配置立即应用到当前会话中去: ```bash sudo service docker restart ``` 最后可以通过查询 Docker 运行状态的方式确认新的镜像源已经被采纳: ```bash sudo docker info | grep Mirrors -A 1 ``` #### 利用 Cloudflare Workers 实现 Docker Hub 加速 另外一种方案则是借助于 Cloudflare Workers 提供的服务端无服务器函数特性来自行为国内用户提供更快捷稳定的访问速度。这通常涉及到注册一个合适的顶级域名并通过 DNS 解析托管给 Cloudflare 处理[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值