相信有很多人使用过流量转发,比如用商家转发到落地机的,那么怎么实现这种转发呢?其实很简单,几行命令搞定,这次俺们用 iptables 来演示一下。
流量走向:
客户端 --> GFW --> A服务器 --> B服务器(落地) --> YouTube --> 返回客户端
A服务器IP:2.2.2.2 端口:20000 B服务器IP:6.6.6.6 端口:60000
实现目的:把本机A服务器IP 2.2.2.2 上的 20000 端口流量转发到B服务器IP 6.6.6.6 的 60000 端口上
A服务器
以下都在A服务器上操作,也就是转发服务器,白话就是线路好的服务器
首先在服务器上开启 tcp 转发:
echo "net.ipv4.ip_forward=1" >> /etc/sysctl.conf
使其生效:
sysctl -p
好像Debian11以上就弃用了iptables,来安装一下:
apt install iptables -y
把A服务器 20000 端口流量转发到B服务器的 60000 端口上
在PREROUTING上修改目的地址:
iptables -t nat -A PREROUTING -p tcp --dport 20000 -j DNAT --to-destination 6.6.6.6:60000
在POSTROUTING上修改源地址:
# 2.2.2.2 是A服务器IP,也就是转发服务器IP
iptables -t nat -A POSTROUTING -d 6.6.6.6 -p tcp --dport 60000 -j SNAT --to 2.2.2.2
# 或者直接用MASQUERADE自动获取源IP,两条命令二选一
iptables -t nat -A POSTROUTING -d 6.6.6.6 -p tcp --dport 60000 -j MASQUERADE
其实上面两条命令就可以用了,为了防止在FORWARD上面被丢弃,添加两条规则允许通过:
iptables -I FORWARD -d 6.6.6.6 -p tcp --dport 60000 -j ACCEPT
iptables -I FORWARD -s 6.6.6.6 -p tcp --sport 60000 -j ACCEPT
最后,为了使规则永久生效,不至于重启服务器后丢失,安装个iptables-persistent
apt install iptables-persistent
安装完成后写入规则,这样就不会丢了:
iptables-save > /etc/iptables/rules.v4
上面就是转发服务器上的操作,下面落地服务器就简单了。用法就同大多卖流量转发的一样了。
B服务器
B服务器也就是落地服务器,在B服务器上安装个Shadowsocks就好了,注意端口使用上面转发的60000端口。
安装一键脚本: https://github.com/yeahwu/v2ray-wss
客户端
本来B服务器上安装的SS的IP和端口是,IP 6.6.6.6,端口 60000
既然使用了转发,那么客户端只要把IP和端口换成A服务器IP,和转发端口20000,就可以使用了。