由于 UDP 限流严重,表现就是晚上某些时候突然丢包高,很卡。
WG 走 TCP 的方式是 tunnel/udp2raw 这些,但是都是没法搭配域名使用。
WG + DDNS 作为 server 端使用。
1
cloudsigma2022 2022-09-09 13:45:54 +08:00
ddns 用 cf 的 。
cf ddns https://gist.github.com/0neday/04141ba4d3ac3ccf77a5b5837b104762 显示 Gist 代码 or nodered https://bbs.hassbian.com/thread-16664-1-1.html 目前使用完美。 |
2
ea3ba5c0 OP @cloudsigma2022 你可能没有理解,不是 DDNS 的问题,而是 tunnel 或者 udp2raw 只能直连 ip 。
|
3
cloudsigma2022 2022-09-09 13:50:22 +08:00
@ea3ba5c0 域名解析问题吧,那就把域名解析直接写死在本地 /etc/hosts 里。
|
4
Kinnice 2022-09-09 14:11:41 +08:00
魔改一下 udp2raw 使其支持域名
或 写个脚本监测 ip 变动,变了就用新 ip 重启相关的进程。 |
5
ghjexxka 2022-09-09 14:32:48 +08:00
手搓配置文件用 v2ray 的 dokodemo-door 协议配合其他 tcp 类型的协议转发可行
|
6
Yadomin 2022-09-09 15:12:45 +08:00 via Android
wg 本身也不支持 ddns ,也是用 cron 脚本刷新的
|
7
titanium98118 2022-09-09 15:48:17 +08:00
把 wg 套进 v2ray ,udp over tcp
|
8
yaoyao1128 2022-09-09 15:50:31 +08:00 via iPhone
自己写一个 cron 脚本处理 udp2raw 试试?
|
10
maybeonly 2022-09-09 16:49:41 +08:00
不是很明白具体要做什么
如果只是某个 ip 要实现 ddns 但是不方便配置的话 随便写个对端地址,比如 100.64.11.22:12345 然后整个脚本监控域名变化并修改 output 串的 dnat 规则。 必要时清理 conntrack 。 |
11
Yadomin 2022-09-09 16:58:44 +08:00 via Android
@ea3ba5c0 不支持的,wg-tools 里有个 reresolve-dns.sh 就是做手动刷新的脚本
|
12
sujin190 2022-09-09 17:00:34 +08:00
tunnel/udp2raw 前面再挂个代理呗,代理转发的时候就可以支持域名解析了吧,本地只是转发流量的话性能也不会有多大损失
|
13
sujin190 2022-09-09 17:01:16 +08:00
tunnel/udp2raw 和远程服务器之间再挂个 tcp 转发代理
|
15
wym0823 2022-09-10 08:24:59 +08:00
去试试这个项目,挺不错,用他的 ws/wss 协议,简单好用
https://github.com/net-byte/vtun |
16
hanssx 2022-09-21 18:47:40 +08:00
最后楼主咋解决的,话说 Windows 下我怎么一直握手失败,看 Github Issues 也很多失败的。
|
19
hanssx 2022-09-22 14:21:08 +08:00
说错了,Windows 下 udp2raw 是不支持这个参数的,服务端加上就好了。
|
20
hanssx 2022-09-22 16:44:28 +08:00
因为我是用 windows 下的 udp2raw ,补充一下 udp2raw 的一个 bat 定时脚本,大家可以测试一下:
``` @echo off setlocal ENABLEDELAYEDEXPANSION set ddns=yourddns for /f "delims= " %%i in ('ping %ddns% -n 1 -w 0 ^|findstr "^[0-9]"') do ( set ip=%%i ) start /b udp2raw_mp.exe -c -l 0.0.0.0:3333 -r !ip!:remote_port -k "passwd" --raw-mode faketcp --cipher-mode aes128cbc :g for /f "delims= " %%i in ('ping %ddns% -n 1 -w 0 ^|findstr "^[0-9]"') do ( if !ip! equ %%i ( timeout /T 300 /NOBREAK >nul ) else ( taskkill /im udp2raw_mp.exe /f ping -n 2 127.1 >nul start /b udp2raw_mp.exe -c -l 0.0.0.0:3333 -r %%i:remote_port -k "passwd" --raw-mode faketcp --cipher-mode aes128cbc set /a ip=%%i )) goto g ``` |