当前位置: 首页 > article >正文

【Tealscale + Headscale + 自建服务器】异地组网笔记

文章目录

  • 效果
  • 为什么要用 Headscale
  • 云服务器安装 Headscale
  • 配置 config.yaml
  • 创建反向代理
  • 搭建管理 UI
  • 授权管理 UI
  • 添加互联设备
  • 参考


效果

首先是连接情况,双端都连接上自建的 Headscale

在这里插入图片描述
在这里插入图片描述
手机使用移动流量,测试一下 ping

在这里插入图片描述
再试试进入游戏

在这里插入图片描述
可以看到是没问题的!

为什么要用 Headscale

比较 WireguardHeadscale 增加了 p2p 的模式,Headscale 会在保证两台异地设备相连的同时,尝试升级到 p2p

在这里插入图片描述

在这里插入图片描述

云服务器安装 Headscale

可以看 Headscale 的官网的安装教程 ,进入云服务器,然后输入如下命令

这里的 HEADSCALE_VERSION 以及 HEADSCALE_ARCH 是版本和你云系统的架构的变量名,填写对应的值,回车

HEADSCALE_VERSION="0.23.0" # See above URL for latest version, e.g. "X.Y.Z" (NOTE: do not add the "v" prefix!)
HEADSCALE_ARCH="amd64" # Your system architecture, e.g. "amd64"
wget --output-document=headscale.deb \
 "https://github.com/juanfont/headscale/releases/download/v${HEADSCALE_VERSION}/headscale_${HEADSCALE_VERSION}_linux_${HEADSCALE_ARCH}.deb"

然后等待下载即可,或者可以下载到本地,然后上传到服务器中

在这里插入图片描述

下载完成后安装 Headscale

在这里插入图片描述

sudo apt install ./headscale.deb

开机自动启动

sudo systemctl enable --now headscale

配置 config.yaml

修改 etc/headscale/config.yaml 文件

# 这里改成你云服务器的 ip 加上 开放的 tcp 端口
server_url: http://你自己的ip/tcp端口

在这里插入图片描述

创建反向代理

apt install -y nginx

这里会卡一下
在这里插入图片描述

然后到 /etc/nginx/sites-available 这个目录下,编辑 default 文件,替换一下的命令

map $http_upgrade $connection_upgrade {
    default      keep-alive;
    'websocket'  upgrade;
    ''           close;
}
server {
    listen 3355;
    listen [::]:3355;
    server_name 云服务器IP;
    location / {
    
    	proxy_pass http://127.0.0.1:8080;
        	proxy_http_version 1.1;
       	proxy_set_header Upgrade $http_upgrade;
        	proxy_set_header Connection $connection_upgrade;
        	proxy_set_header Host $server_name;
        	proxy_buffering off;
        	proxy_set_header X-Real-IP $remote_addr;
        	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        	proxy_set_header X-Forwarded-Proto $http_x_forwarded_proto;
        	add_header Strict-Transport-Security "max-age=15552000; includeSubDomains" always;

    }
    
    location /web {
		index  index.html;
       	alias  /var/www/web;
	}
}


搭建管理 UI

然后下载这个 ui 项目 https://github.com/gurucomputing/headscale-ui,解压到制定目录

在这里插入图片描述

之后开启 headscale 服务,重启 nginx

在这里插入图片描述

systemctl start headscale
systemctl restart nginx

创建一个 apikeys 用于给网页授权

headscale apikeys create --expiration 9999d 

在这里插入图片描述

之后访问 http://ip:端口号/web 就可以了


授权管理 UI

在这里插入图片描述

接着把生成的密钥粘贴到这里

在这里插入图片描述


添加互联设备

之后新增一个User view 即可,这是我添加的两个设备

在这里插入图片描述

然后我在安卓端,用流量连接服务器,并 ping 我的 mac

在这里插入图片描述

之后我的 mac 端也可以链接并 ping 通我的手机

在这里插入图片描述

参考

  1. Tailscale玩法之内网穿透、异地组网、全隧道模式、纯IP的双栈DERP搭建、Headscale协调服务器搭建,用一期搞定,看一看不亏吧?
  2. Tailscale 官方手册

http://www.kler.cn/a/403349.html

相关文章:

  • 第 24 章 -Golang 性能优化
  • 136.flask内置jinja2模版使用
  • 从 IDC 到云原生:稳定性提升 100%,成本下降 50%,热联集团的数字化转型与未来展望
  • web——sqliabs靶场——第十五关——post时间盲注
  • RFdiffusion rigid_from_3_points函数解读
  • C语言和C++的不同
  • ESP32-S3模组上跑通esp32-camera(21)
  • 2024/11/17周报
  • 网络属性及相关配置常用命令-下篇
  • 腾讯:将LLM排序能力迁移至BERT
  • cesium for unity的使用
  • Flink整合Hudi及使用
  • 视频修复技术和实时在线处理
  • 用Python爬虫“偷窥”1688搜索词推荐:一场数据的奇妙冒险
  • 国内几大网络安全公司介绍 - 网络安全
  • 聊一聊Elasticsearch的索引分片的恢复机制
  • C#无符号整数类型详解:声明、使用及注意事项
  • Android:时间选择器(最下面有效果图)
  • 【设计模式】【创建型模式(Creational Patterns)】之单例模式
  • 实现两个表格的数据传递(类似于穿梭框)
  • 代码随想录---八股文训练营Day40(总结)
  • 【Unity/Animator动画系统】多层动画状态机实现角色的基本移动
  • 散户持股增厚工具:智能T0算法交易
  • ProtonBase × Data for AI Meetup·杭州站
  • 深度学习:神经网络中线性层的使用
  • 网络协议之邮件协议(SMTP、POP3与IMAP)