有域名但是没有带公网IP的服务器,怎么能够让服务通过域名暴露出去?

有域名但是没有带公网IP的服务器,怎么能够让服务通过域名暴露出去?

我的域名是在腾讯云上的,同时我有一台本地的主机,我准备将这台主机作为个人服务器部署一些自己的服务,但是我经常和我的服务器不在同一个局域网下,并且我希望不止有我一个人可以访问这个服务。

如果只是不在一个局域网下,只希望自己能够访问就行,那可以用一些简单的方法,比如使用 tailscale 这种自组局域网,或者使用 cloudflared 的隧道功能。

我的方案主要依赖于 cloudflared,需要提前注册一个 cloudflared 账号。

修改 NS

首先需要将域名的 DNS Server 简称 NS 交由 cloudflared,这部分可以参考一些互联网上的教程,比较简单(说我放连接是诱导,受不了这个审核机制,只有读者自己搜了),腾讯云切换 NS 可以去腾讯云官网上搜索文档。

修改 NS 以后 cloudflared 才有权限管理域名的 DNS,后续需要创建 DNS 纪录将域名关联到开通的隧道。

配置隧道

为了可以从公网访问某个机器,可以使用隧道,而 cloudflared 就提供隧道服务,有免费版,还是很不错的。

进入 cloudflared 的控制面板,在左侧的 networking 部分找到 tunnels,或者直接在左侧导航去的顶部搜索 tunnel,进入隧道的控制面板,开始创建一个隧道。

在填写完隧道名称以后,选择目标系统、机器架构,按照提示在服务器上安装好 cloudflared,并启动 tunnel

虽然提示中的命令可能包含了认证的密钥,但是我在服务器上启动隧道的时候还是有未认证的提示,可以执行 cloudflared login 通过打开的网页重新登录一下。

隧道路由

完成上面两部分以后,我们有两个主要资源:"域名" 和 "隧道",这两部分还没有关联起来,通过域名无法知道隧道,所以还需要绑定一下。有两种方法都可以完成:

  1. 通过命令行完成:
bash 复制代码
cloudflared tunnel route dns <隧道名> <域名>

这个命令会在 DNS - Records 中创建一个 DNS 记录,将域名解析到隧道上。

  1. 通过图形化界面完成

在左侧导航中查找 DNS - Records,手动在域名上创建一个 DNS 记录,类型为 tunnel

服务路由

现在通过域名能够将流量导航到隧道,但是隧道不知道将流量转发到服务器上的哪儿个地方,所以还需要在隧道的控制面板中,创建一个路由。

点击 Add Route,选择 Published Application,填写必要部分,确认即可。

测试

我是在我的服务器上有一个 k3s 集群,其中自带 traefik,监听了 80 端口,所以我将隧道的路由绑定为 http://localhost:80,访问我的域名可以出现 404 页面。

如果是"服务路由"之前的步骤出了问题,访问域名大概是直接浏览器报错,显示找不到网站,如果是"服务路由"配置错误,比如把 http://localhost:80 配置为了 https://localhost:80,访问域名会出现 cloudflaredBad Gateway 错误。

在配置域名和隧道之前请保证服务器的服务正常在某个端口,避免后续出问题难以排查。

相关推荐
lihui_cbdd33 分钟前
HPC 集群上 OpenMM GPU 多版本安装实战指南
运维·服务器·人工智能·计算化学
Xpower 1741 分钟前
MCP 服务器暴露在公网:AI Agent 工具层正在变成新的安全边界
服务器·人工智能·安全
深圳市晶科鑫实业有限公司2 小时前
5G与AIoT时代:如何选择晶振常用频率?
服务器·单片机·物联网·5g·智能路由器·健康医疗·信息与通信
wanhengidc3 小时前
双线服务器有哪些优点?
运维·服务器
缪懿3 小时前
网络层和数据链路层中的常见协议解析
网络·网络协议·java-ee
jscxy52063 小时前
ospf综合实验
运维·服务器·网络
IP搭子来一个4 小时前
爬虫使用代理 IP 频繁失效,该如何定位问题?
网络·爬虫·tcp/ip
KaMeidebaby4 小时前
卡梅德生物技术快报|酵母双杂交 cDNA 文库构建与蛋白互作筛选流程
服务器·前端·数据库·人工智能·算法
田里的水稻4 小时前
OE_永久配置网络_linux系统终端命令行ip_setting
人工智能·网络协议·机器人·运维开发
csdn_aspnet4 小时前
Modbus TCP C# 客户端程序
服务器·网络·tcp/ip·c#