【Tailscale】DERPer中继从源码的搭建及Headscale导入
💡
原文中文,约7600字,阅读约需18分钟。
📝
内容提要
DERP是Tailscale的中继服务器,负责客户端连接信息的交换和流量中继。由于国内网络环境特殊,官方节点连接延迟和稳定性差,因此需要自行编译DERP。本文记录了DERP的编译、安装和运行过程,包括使用Tailscale客户端接入Tailnet和配置NGINX反向代理,最后检查DERP节点是否成功添加。
🎯
关键要点
- DERP是Tailscale的中继服务器,负责客户端连接信息的交换和流量中继。
- 由于国内网络环境特殊,官方节点连接延迟和稳定性差,需要自行编译DERP。
- DERP程序是基于Go构建的二进制文件,官方未提供预编译包。
- 编译DERP需要下载Go环境并使用Go命令构建derper二进制文件。
- 安装Tailscale客户端以接入自己的Tailnet网络,防止DERP服务器被其他用户使用。
- 在阿里云ECS上使用Tailscale时需注意MagicDNS地址与内网DNS冲突。
- 运行DERPer时可以选择不同的命令配置,支持HTTPS和HTTP端口跳转。
- 使用NGINX反向代理可以更好地隐藏服务特征,配置简单。
- 在headscale的config.yaml中设置DERP列表,重启headscale服务以应用配置。
- 使用tailscale netcheck检查DERP节点是否添加成功,并获得延迟信息。
❓
延伸问答
什么是DERP服务器,它的主要功能是什么?
DERP是Tailscale的中继服务器,负责交换客户端之间的连接信息和在无法直接连接时中继流量。
为什么需要自行编译DERP而不是使用官方节点?
由于国内网络环境特殊,官方节点连接延迟和稳定性差,因此需要自行编译DERP以提高连接质量。
如何编译DERP程序?
需要下载Go环境并使用Go命令构建derper二进制文件,具体步骤包括解压Go环境、进入目录并执行安装命令。
在阿里云ECS上使用Tailscale时需要注意什么?
需要注意MagicDNS地址与阿里云内网DNS冲突,可能导致服务器联网出现问题。
如何使用NGINX反向代理DERP服务?
可以通过配置NGINX的反向代理,将DERP服务隐藏并与其他网站共存,具体配置包括设置proxy_pass和相关头信息。
如何在headscale中添加DERP节点?
需要在headscale的config.yaml中设置DERP列表,并重启headscale服务以应用配置。
➡️