Tailscale:基于 WireGuard 异地组建虚拟局域网

文章分享 6个月前 yuyu
207 0

Tailscale:基于 WireGuard 异地组建虚拟局域网

说明: Tailscale 是一款基于 Wire­Guard® 保护的虚拟局域组网工具,相信使用过 ZeroTier 对虚拟局域网应该也有所了解,虚拟局域网与本地组网的最大差别在于设备与设备之间允许不在一个机房、国家甚至地区,但通过 P2P 或者中转节点,通过异地组网最终实现局域网的效果。

Tailscale:基于 WireGuard 异地组建虚拟局域网

没有公网 IP,又想能满足远程办公需求?担心暴露公网 IP 而被频繁的恶意扫描、攻击?Tailscale 的诞生,成为解决这些痛点的全新选择。

Tailscale:基于 WireGuard 异地组建虚拟局域网

功能特点

  • 无需注册,授权登录,开箱即用;
    • 无需配置防火墙;
    • 没有额外的配置。
  • 高安全性、私密性;
    • 自动密钥轮换
    • 基于 WireGuard® 保护
    • 点对点连接
    • 支持用户审查端到端的访问记录
  • 访问 / 连接,高度可控
    • 支持使用节点共享与指定的 Tailscale 用户共享您的设备。
    • 支持使用ACL限制对设备的访问。
  • 低延时,不限速。
    • 设备间在不跨运营商的前提条件下,设备所在网络环境的上行带宽就是访问下载的最大带宽。

安装使用教程

至少两台设备来设置和配置 Tailscale 网络。
Tailscale 官网地址:https://tailscale.com/
Tailscale 下载地址:https://tailscale.com/download
注:免费用户最多支持 20 个设备,加入更多设备需要花银子。

群晖 NAS 安装使用 Tailscale

以群晖为例 –> 下载 Tailscale ,然后到 套件中心 手动安装 spk 文件。

Tailscale:基于 WireGuard 异地组建虚拟局域网

安装完成后,进入终端 ssh,执行 sudo tailscale up 命令,或者直接打开 Tailscale 进入授权登录页面。(国内网络环境推荐使用巨硬)

Tailscale:基于 WireGuard 异地组建虚拟局域网

授权登录成功后,会自动为该设备分配一个 Tailscale IP(可用于局域网内设备间的访问)

Tailscale:基于 WireGuard 异地组建虚拟局域网

群晖 NAS 如果作为被访问端,需要访问端(例如电脑)同时下载安装 Tailscale 并授权设备登录成功后才能通过被访问端(群晖 NAS) 的 Tailscale IP 或 设备名 进行远程访问。

OpenWrt 安装使用 Tailscale

SSH 终端进入 Open­Wrt ,下载 openwrt-tailscale-enabler -> Releases 发布页面

# 进入 tmp 目录
cd /tmp

# 下载 openwrt-tailscale-enabler
wget https://github.com/adyanth/openwrt-tailscale-enabler/releases/download/v1.12.3-8f0308e-autoupdate/openwrt-tailscale-enabler-v1.12.3-8f0308e-autoupdate.tgz

提取文件覆盖到系统根目录:

tar x -zvC / -f openwrt-tailscale-enabler-v1.12.3-8f0308e-autoupdate.tgz

安装依赖:

# 更新包列表
opkg update

# 安装依赖
opkg install libustream-openssl ca-bundle kmod-tun

首次运行:

# 启动 tailscale 守护进程
/etc/init.d/tailscale start

# 屏幕打印 tailscale 登录地址,进行授权登录
tailscale up --accept-dns=false

运行以上两个命令,会自动在 /tmp 目录下载 tailscale 包文件包含了 tailscale 和 tailscaled 二进制文件,并自动解压、移动到 /usr/bin 目录。

可能出现的问题:例如 Open­Wrt x86_64 平台会请求下载 tailscale_1.12.3_x86_64.tgz 包文件(实际发布页并无此包而导致报错),需要自行在 版本发布页 下载 tailscale_1.12.3_amd64.tgz 到/tmp目录解压,并将 tailscale 和 tailscaled 二进制文件移动到 /usr/bin 目录,最后再重新执行上面两行命令即可。

开机启动:

# 加入开机启动
/etc/init.d/tailscale enable

# 验证是否成功加入开机启动项:
ls /etc/rc.d/S*tailscale*

版本更新:

在 这里 找到适应平台架构的包文件,下载解压替换 Open­Wrt 中的 /usr/bin/tailscale 和 /usr/bin/tailscaled 这两个文件。

关于设备的 Tailscale IP,可运行 ip addr show tailscale0 命令获取。或者访问 管理面板 在 Machines(设备列表)中查看。

Docker 安装使用 Tailscale

官方提供了 Dock­er­file -> 传送门,大家可以自行构建 docker 镜像来运行容器,也可以直接使用 fastandfearless/tailscale 这个镜像,安装使用如下:

创建并运行容器:

docker run -d --name=tailscaled -v /var/lib:/var/lib -v /dev/net/tun:/dev/net/tun --network=host --privileged fastandfearless/tailscale tailscaled

验证机器并将其连接到 Tailscale 网络:

# 屏幕打印 tailscale 登录地址,进行授权登录
docker exec tailscaled tailscale up

获取设备的 Tailscale IP 地址:

ip addr show tailscale0

查看设备状态:

docker exec tailscaled tailscale status

CentOS 7 安装 Tailscale

注:该软件包支持 x86 和 ARM CPU 架构,包括 32 位和 64 位系统。

安装 yum-utils

yum install yum-utils

添加 YUM 源,并安装 Tailscale

yum-config-manager --add-repo https://pkgs.tailscale.com/stable/centos/7/tailscale.repo
yum install tailscale

添加开机启动,并启动服务

systemctl enable --now tailscaled

验证机器并将其连接到 Tailscale 网络

tailscale up

复制屏幕打印的登录地址,使用浏览器访问进行授权登录。如果使用 @gmail.com 地址登录,则会自动获得授权。

获取设备的 Tailscale IP 地址

ip addr show tailscale0

在其他终端设备安装 Tailscale

Tailscale 目前已支持了 Linux 、ma­cOS、iOS、Win­dows、An­droid、Syn­ol­ogy、Rasp­berry Pi & ARM 等平台,几乎做到了终端设备的全面覆盖。

Tailscale:基于 WireGuard 异地组建虚拟局域网

在 Tailscale 下载中心 选择下载对应平台的应用,并通过登录同一个账号使设备都在同一个虚拟局域网内,只有加入局域网的设备才支持设备间的连接。

访问内网子设备

局域网内部分终端设备不支持安装 Tailscale,该怎么办? 并非所有设备都需要安装 Tailscale,只需要确保在同一个局域网内至少有一个设备安装通过内网转发也能实现对内网其他设备的访问。以其中一台 Linux 设备作为子网路由网关为例,操作如下:

# 设置IP转发
cat >> /etc/sysctl.conf <<EOF
net.ipv4.ip_forward = 1
net.ipv6.conf.all.forwarding = 1
EOF

# 使配置生效
sysctl -p /etc/sysctl.conf

将局域网所在内网网段暴露给 Tailscale:

tailscale up --advertise-routes=192.168.2.0/24

注:上面命令行中 192.168.2.0/24 需要换成自己的局域网网段(免费版仅支持加入一个子网路由网关)。然后进入 tailscale 控制台,找到显示局域网网段地址的机器,点击 -> Edit route settings

Tailscale:基于 WireGuard 异地组建虚拟局域网

开启 Subnet routes 按钮,如下:

Tailscale:基于 WireGuard 异地组建虚拟局域网

通过以上步骤 Win­dows、ma­cOS、iOS、An­droid 客户端会自动更新子网路由。而对于 Linux 客户端,默认情况下仅使用 Tailscale 的 100.x 地址,不能主动发现新的子网路由,需要运行下面命令行,启用新的子网路由:

tailscale up --accept-routes

实际效果:身处天涯海角只要有网络,将设备连接 Tailscale 便能访问 192.168.2.0/24 (你的局域网段)内的所有设备,实际测试晚间时段电信 -> 联通的网络延迟 600ms 左右延迟会有些高,不要有太高的预期。

设备禁用密钥过期

Tailscale 一般每隔 6 个月会要求重新进行身份验证,以确保网络安全。为避免发生这种情况时访问中断,请访问 管理面板 在 Machines(设备列表)中找到需要禁用的设备,并选择 Disable Key Expiry (禁用密钥过期),让设备免受中断的长期使用下去。

Tailscale:基于 WireGuard 异地组建虚拟局域网

写在最后

体验了一个下午发现 Tailscale 的最大优点是打洞的成功率比 Ze­roTier 高太多,缺点 CPU 占用非常高(非常高)

栏目:文章分享 归档:2022年 06月 10日
版权声明:yuyu 发表于 2022-06-10 10:50:02。
转载请注明:Tailscale:基于 WireGuard 异地组建虚拟局域网 | 0660HAO