大家好,目前我有三台电脑 A,B,C 分布在不同地方, A 和 B 电脑各自通过 wireguard 连接到 C,并且 A 和 B 能成功通讯。
A =====> C <===== B
我的目标是让 A 的流量全部由 B 转发出去。
请问如何用 iptables 或者 nginx 等工具实现?
1
Damn 2022-08-30 12:04:30 +08:00
跟我差不多,但我 ABC 互联,你要不要考虑一下?
你可能是只有 C 有公网 ip ? 如果 B 是锥形 nat 可以借助 C 打洞的。 |
2
Damn 2022-08-30 12:07:00 +08:00
如果一定要 A 通过 C 连接到 B 作为出口的话,在 C 的路由表上添加一条记录就行了。
|
3
yorkyoung 2022-08-30 12:33:24 +08:00
如果没猜错你的意图的话 直接在 B 搭个 gost 服务端就能实现
|
4
leonunix 2022-08-30 12:35:07 +08:00
C 上要开 2 个 wireguard 进程,就是要 2 个端口 A ,B 。
A 连接 A allow 0.0.0.0/0 B 连接 B allow 0.0.0.0/0 然后 A 上加 0.0.0.0/0 路由表到 B 就可以了 |
5
Richardyyz OP @Damn 三台电脑都有公网 IP ,并且 ABC 目前都可以相互通信。能具体说说在 C 的路由表上加什么记录吗?感谢啦
|
6
Richardyyz OP @leonunix 需要两个 namespaces 吗?
|
7
Damn 2022-08-30 14:38:01 +08:00 via iPhone
@leonunix 你是 wg-go 么,不然 wg 工作在内核里的,只需要写配置文件,怎么会有进程呢。。。
@Richardyyz 假设 A 10.0.0.1/24 连接到 C allow 0.0.0.0/0 B 10.0.0.2/24 连接到 C allow 10.0.0.0/24 C 10.0.0.3/24 接受 AB allow 10.0.0.0/24 C 添加路由表 10.0.0.1 mask 0.0.0.0 route 10.0.0.2 (意会即可,根据系统不同修改) |
8
Damn 2022-08-30 14:39:23 +08:00 via iPhone
C 可能要改成 10.0.0.3/32
allow 10.0.0.1/32 和 10.0.0.2/32 |
9
joshu 2022-08-30 17:25:31 +08:00
ip route add default via <link-ip-of-B-on-interface-between-C-and-B> dev <interface-between-C-and-B> table <table_id or table_name>
ip rule add iif <interface-between-A and C> lookup <table_id or table_name> pref 50 如果用 table_id ,那就用数字,如果用 table_name ,在 /etc/iproute2/rt_tables 加上一行数字和名称的对应关系 如果是三层设备连接,可以不加 via XXX ,直接 dev XXX 就行 也可以用 vrf 来实现,从而避免写 ip rule 规则 |
10
yohole 2022-08-30 17:27:59 +08:00
我印象中 wireguard 只解决内网或者穿透问题,但是流量转发需要单独搭建多一个服务才行
|
11
leonunix 2022-08-31 09:06:38 +08:00
|
12
manfred4527 2022-08-31 10:20:45 +08:00
首先 A 和 B 连接公网 C 后,A 和 B 是可以直接通信的,C 不开 NAT 出口。
然后 A 和 B 直接再套娃点对点建立 VPN 行不?如 GRE-tunnel 之类的。 |
13
Richardyyz OP @leonunix A 点不能写路由表,只能在 C 点或者 B 点进行操作。请问有其他方法吗?
|
14
Richardyyz OP @joshu 请问这两行命令是写在 C 点上吗?
|
15
Richardyyz OP @Damn 刚才试了一下,最后在 C 点上尝试添加路由表,发现不能 mask 0.0.0.0 ,返回的是 Invalid Argument.
我在 ubuntu 上尝试的命令:sudo route add -net 10.0.0.1 netmask 0.0.0.0 gw 10.0.40.2 |
16
szdosar 2022-09-02 13:56:36 +08:00
跑个题,ABC 都有公网了,你何不直接在 B 安装个 v2r 代理服务端,然后 B 安装个 v2r 客户端实现?
|
17
szdosar 2022-09-02 14:51:34 +08:00
跑个题,ABC 都有公网了,你何不直接在 B 安装个 v2r 代理服务端,然后 A 安装个 v2r 客户端实现?
|
18
joshu 2022-09-02 18:00:38 +08:00 via Android
@Richardyyz 对
|
19
darrh00 2022-09-03 22:57:36 +08:00
装个 tailscale 一切搞定,用节省出来的时间想想如何赚钱不好吗?
|
20
Richardyyz OP @darrh00 这里只想纯粹交流一下技术。而且我也不需要去想如何赚钱。
|
21
ghostwwg 2022-09-04 00:05:50 +08:00
ABC 都有公网的话,网络模型就是蜂窝式的了,A 节点上 B 节点的路由宣告 0.0.0.0 ,A B 通讯和 C 没有关系了。如果是 C 网关模式的话,可以考虑 B 做个 http 代理,A 配置 http 代理也行。
|
22
HawkinsSherpherd 2022-09-04 00:47:59 +08:00
这个静态路由就搞定了。
C 上开两个 WG 接口,配两个网段的 IP 地址。 A 上把默认路由指向 C ,B 上写静态路由把 A-C 互联的网段指向 C 。 我就干过这种中转的事情。 |
23
Richardyyz OP @HawkinsSherpherd 请问能具体说一下吗?感谢啦
|
24
Richardyyz OP 有偿征集具体方法哈 UmljaGFyZF9ZdXpoZW4=
|
25
Richardyyz OP 综合楼上各位的建议,已经顺利解决问题了,感谢各位。
|
26
tomychen 2022-09-04 20:54:50 +08:00
A 到 C 取到 10.0.0.2
B 到 C 取到 10.0.0.254 由于 B 和 C 已经同处 10.0.0.x 子网,所以在 B 上先打开转发 sysctl.conf iptables -t nat -A POSTROUTING -s 10.0.0.2/32 -j MASQUERADE A 网关调整为 10.0.0.254 或做静态路由 |
27
zdf 2022-11-09 21:28:41 +08:00
@Richardyyz 能请问一下具体最后是怎么解决的吗?谢谢。
|