AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / computer / 问题 / 1819292
Accepted
cruunnerr
cruunnerr
Asked: 2023-12-04 19:56:52 +0800 CST2023-12-04 19:56:52 +0800 CST 2023-12-04 19:56:52 +0800 CST

Nginx 代理管理器和 VPS 上的 Wireguard - 正确路由

  • 772

我家里有一个 ISP,可以为我提供 CGNAT。

所以我有一个 VPS 作为 Wireguard 服务器并运行。在我的家庭实验室中,我有一个安装了 Ubuntu 和 Nginx 代理管理器的虚拟机。在此虚拟机上,我还安装了wireguard 以连接到VPS。

拓扑图:

拓扑图

在我的 LAN 中,NginxProxyManager (NPM) GUI 可在 172.16.0.9:81 上使用

路由按预期工作。如果我通过子域连接到公共 VPS,我会看到我的网络服务器。所以效果很好。但我必须在 NPMwireguard 配置上使用“AllowedIPs=0.0.0.0/0”。任何其他配置都不起作用。

就我打开wireguard隧道而言,我根本无法通过本地网络连接到我的NPM。但它有互联网连接。它与AllowedIPs 配置有关。

我访问https://www.procustodibus.com/blog/2021/03/wireguard-allowedips-calculator/ 并尝试了许多不同的配置,禁止本地地址范围等......但没有任何效果。我可以通过 VPS 的公共 IP 访问我的网络服务器,也可以在本地访问我的 NPM,但不能同时访问。

到目前为止,这是我的配置:

VPS配置:

[Interface]
PrivateKey = ****
ListenPort = 51999
Address = 192.168.200.1/24

PostUp = iptables -t nat -A PREROUTING -p tcp -i ens192 '!' --dport 22 -j DNAT --to-destination 192.168.200.2
PostUp = iptables -t nat -A POSTROUTING -o ens192 -j SNAT --to-source z.z.z.z
PostUp = iptables -t nat -A PREROUTING -p udp -i ens192 '!' --dport 51999 -j DNAT --to-destination 192.168.200.2
PostUp = iptables -A FORWARD -i wg0 -o ens192 -j ACCEPT
PostUp = iptables -A FORWARD -i eth0 -o wg0 -j ACCEPT

PostDown = iptables -t nat -F
PostDown = iptables -F FORWARD;

[Peer]
PublicKey = *****
AllowedIPs = 192.168.200.2/32

NPM 配置:

[Interface]
PrivateKey = ****
Address = 192.168.200.2/24

[Peer]
PublicKey = ****
AllowedIPs = 0.0.0.0/0
Endpoint = z.z.z.z:51999
PersistentKeepalive = 25

编辑: 在 NPM 线卫上,在我打开隧道之前,我得到了:

IP路由:

default via 172.16.0.1 dev ens18 proto static
172.16.0.0/24 dev ens18 proto kernel scope link src 172.16.0.9
172.17.0.0/16 dev docker0 proto kernel scope link src 172.17.0.1 linkdown
172.18.0.0/16 dev br-00d63081655a proto kernel scope link src 172.18.0.1

ip规则:

0:      from all lookup local
32766:  from all lookup main
32767:  from all lookup default

打开隧道后:

IP路由:

default via 172.16.0.1 dev ens18 proto static
172.16.0.0/24 dev ens18 proto kernel scope link src 172.16.0.9
172.17.0.0/16 dev docker0 proto kernel scope link src 172.17.0.1 linkdown
172.18.0.0/16 dev br-00d63081655a proto kernel scope link src 172.18.0.1
192.168.200.0/24 dev wg0 proto kernel scope link src 192.168.200.2

ip规则:

0:      from all lookup local
32764:  from all lookup main suppress_prefixlength 0
32765:  not from all fwmark 0xca6c lookup 51820
32766:  from all lookup main
32767:  from all lookup default
vpn
  • 1 1 个回答
  • 90 Views

1 个回答

  • Voted
  1. Best Answer
    Tom Yan
    2023-12-05T19:46:27+08:002023-12-05T19:46:27+08:00
    32764:  from all lookup main suppress_prefixlength 0
    32765:  not from all fwmark 0xca6c lookup 51820
    32766:  from all lookup main
    

    首先你需要了解这里的ip规则的含义,尤其是第一个。当您使用 时AllowedIPs = 0.0.0.0/0,wg-quick 并不完全使您的系统将所有非 WG 封装的流量路由出 wg 接口。这里的顶级规则实际上意味着除表default中的路由之外的所有路由main仍将被使用,因为它是唯一前缀长度等于或小于 的路由0。(default基本上是 的别名0.0.0.0/0。)

    通常,主机为其“本地网络”拥有特定的路由,即“前缀路由”。但是,在您的情况下,显然您所说的“本地网络”实际上是一个对于 NPM 主机“远程”的网络。

    我不会在这里深入探讨我们如何定义网络是“本地”还是“远程”,无论如何它不是问题的根本原因,但它或多或少会导致根本原因,即,您的main表没有default覆盖此相关“本地网络”(即10.0.0.0/8)的特定/非路由。结果是,目的地属于子网的流量将被路由到隧道中,而不是172.16.0.1进一步转发,因为表default中的路由main实际上被表中的51820路由覆盖(标记的 WG 封装的流量被例外)。

    10.0.0.0/8因此,恕我直言,最简单的解决方案是向表中添加特定的路由main(而不是与Table=您ip rule自己混淆)。这假设您不需要从10.0.0.0/8VPS 端的另一个(在任何时候都没有进行源 NAT/IP 伪装)访问 NPM。(例如,假设您有一堆属于同一网络的 VPS,并且使用10.0.0.0/8该网络或其子集。)

    FWIW,如果这个“本地网络”实际上没有前缀长度/8(但例如,实际上只是第一个八位字节/24)10,那么最好更具体地进行路由。

    • 0

相关问题

  • 为什么 Little Snitch 拒绝从 vpn.btguard.com 到 openvpn 的传入连接?

  • Cisco anyconnect 不断断开连接并重新连接

  • 802.1X 绕过/MAC 欺骗预防

  • 任何设备上的 OpenVPN - 仅转发 DNS

  • OpenVPN 可以连接,流量有效但我不在本地网络中

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何减少“vmmem”进程的消耗?

    • 11 个回答
  • Marko Smith

    从 Microsoft Stream 下载视频

    • 4 个回答
  • Marko Smith

    Google Chrome DevTools 无法解析 SourceMap:chrome-extension

    • 6 个回答
  • Marko Smith

    Windows 照片查看器因为内存不足而无法运行?

    • 5 个回答
  • Marko Smith

    支持结束后如何激活 WindowsXP?

    • 6 个回答
  • Marko Smith

    远程桌面间歇性冻结

    • 7 个回答
  • Marko Smith

    子网掩码 /32 是什么意思?

    • 6 个回答
  • Marko Smith

    鼠标指针在 Windows 中按下的箭头键上移动?

    • 1 个回答
  • Marko Smith

    VirtualBox 无法以 VERR_NEM_VM_CREATE_FAILED 启动

    • 8 个回答
  • Marko Smith

    应用程序不会出现在 MacBook 的摄像头和麦克风隐私设置中

    • 5 个回答
  • Martin Hope
    Vickel Firefox 不再允许粘贴到 WhatsApp 网页中? 2023-08-18 05:04:35 +0800 CST
  • Martin Hope
    Saaru Lindestøkke 为什么使用 Python 的 tar 库时 tar.xz 文件比 macOS tar 小 15 倍? 2021-03-14 09:37:48 +0800 CST
  • Martin Hope
    CiaranWelsh 如何减少“vmmem”进程的消耗? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Windows 10 搜索未加载,显示空白窗口 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    andre_ss6 远程桌面间歇性冻结 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney 为什么在 URL 后面加一个点会删除登录信息? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension 鼠标指针在 Windows 中按下的箭头键上移动? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca 我所有的 Firefox 附加组件突然被禁用了,我该如何重新启用它们? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK 是否可以使用文本创建二维码? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 更改 git init 默认分支名称 2019-04-01 06:16:56 +0800 CST

热门标签

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve