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 / 问题 / 1789899
Accepted
Manitoba
Manitoba
Asked: 2023-06-19 18:08:51 +0800 CST2023-06-19 18:08:51 +0800 CST 2023-06-19 18:08:51 +0800 CST

无法在多个 RPi 之间转发数据包

  • 772

我有一个可以连接互联网的家庭路由器。我还有一台计算机,但无法直接连接到路由器。希望我有两个我不知道该怎么办的树莓派。

在此输入图像描述

我根据@User1686的回答在 PI #1 上运行了以下命令:

    # Set static IP for eth0 interface
    ip addr add 192.168.1.100/24 dev ppp0
    
    # Set static IP for ppp0 interface
    ip addr add 192.168.0.1/24 dev ppp0

    # Enable IP forwarding
    echo 'net.ipv4.ip_forward = 1' >> /etc/sysctl.conf
    echo 'net.ipv6.conf.all.forwarding=1' >> /etc/sysctl.conf
    sysctl -p /etc/sysctl.conf

    # Route packets to PI #2
    ip route add 192.168.2.0/24 via 192.168.0.2 dev ppp0

    # Masquerade all outgoing packets with his own IP
    iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE

并在 PI #2 上运行以下命令:

    # Set static IP for eth0 interface
    ip addr add 192.168.2.1/24 dev eth0
    
    # Set static IP for ppp0 interface
    ip addr add 192.168.0.2/24 dev ppp0

    # Enable IP forwarding
    echo 'net.ipv4.ip_forward = 1' >> /etc/sysctl.conf
    echo 'net.ipv6.conf.all.forwarding=1' >> /etc/sysctl.conf
    sysctl -p /etc/sysctl.conf

    # Forward packets to PI #1
    ip route add default via 192.168.0.1
    ip route add 192.168.1.0/24 via 192.168.0.1 dev ppp0

    # Masquerade all outgoing packets with his own IP
    iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE

我还在计算机上启用了静态 IP 以连接到 PI #2:

    # Set static IP
    ip addr add 192.168.2.100/24 dev eth0

    # Forward packets to PI #2
    ip route add default via 192.168.2.1

    # Add DNS server
    echo "nameserver 8.8.8.8" | sudo tee -a /etc/resolv.conf

我遇到了一些问题,因为我无法从我的计算机访问某些 IP 和互联网。这是我尝试过的快速表格:

命令 圆周率 #1 圆周率#2 电脑 HomeRouter 上的任何设备
平 192.168.0.1 好的 好的 好的 没有
平 192.168.0.2 好的 好的 好的 没有
平 192.168.1.1 好的 好的 好的 好的
ping 192.168.2.1 好的 好的 好的 没有
平 192.168.1.100 好的 好的 好的 好的
平 192.168.2.100 好的 好的 好的 没有
卷曲8.8.8.8 好的 好的 好的 好的
卷曲 google.com 好的 好的 好的 好的

根据@User1686的回答,我的计算机现在能够与我的家庭路由器上的其他设备进行通信,但它们现在能够与我的计算机进行通信(ping 192.168.2.100例如)。

有没有一种方法可以在不编辑路由器配置的情况下路由数据包?

networking
  • 1 1 个回答
  • 27 Views

1 个回答

  • Voted
  1. Best Answer
    user1686
    2023-06-19T19:06:11+08:002023-06-19T19:06:11+08:00

    简而言之,每个设备都需要为每个非本地网络提供路由。仅仅有一条通往设备的路由是不够的——设备还需要有一条返回您的路由。

    在某些情况下,它可能已经被“默认”路由覆盖(例如,HomeRouter←Pi#2 可以通过 Pi#2 的默认路由到达),但并非在所有情况下都是如此。

    1. 家庭路由器应具有 192.168.0.0/24 和 192.168.2.0/24 的路由。现在,它从 Pi#2 接收到您的 ping,但无法响应(或者更确切地说,它的响应通过 WAN 链接)。

      (在这两种情况下,需要将最近的路由器(即 Pi#1)指定为“网关”。)

    2. Pi #1 需要 192.168.2.0/24 的路由。你已经有了这个。

    3. Pi #2 需要 199.168.1.0/24 的路由。您已经拥有它,既作为显式路由又作为默认路由(可能)。

    4. 最后,计算机应该只有一条通过 Pi #2 的“默认”路由(即 0.0.0.0/0 路由)。现在,除了子网路由之外,它可能根本没有任何路由。

    如果家庭路由器不支持配置静态路由,您也许可以使用 SNAT 作为解决方法 - 让 Pi#1 通过 iptables 使用自己的地址伪装所有数据包。但是,请记住,伪装仅有助于仅在一个方向(出站)建立的连接;它无助于发送“新”数据包入站。

    因此,将 SNAT/MASQUERADE 的使用保持在绝对最低限度,并尽可能使用正常路由 - 例如,如果 HomeRouter 是问题所在(无法执行静态路由),则仅在 Pi#1 上面向 HomeRouter 的接口上使用 SNAT(即在路由网络的边缘)。您不需要 Pi#2 上的额外 SNAT。

    如果您需要通过被迫使用 SNAT 的接口进行入站连接,典型的解决方法是使用 DNAT(又名“端口转发”)——创建一条与 Pi#1 的某些连接相匹配的规则,并对它们进行 DNAT电脑。

    (它不需要逐个端口 - 您也可以将整个第二个 IP 地址分配给 Pi#1,并专门使用它来将该地址的所有内容 DNAT 到计算机,有点像“DMZ”功能在路由器中。)


    由于您已经在使用ip route,我还建议您不要ip addr add 192.168.2.100/24 dev eth0使用 ifconfig。(ifconfig 仍然存在的最大问题(即使在最新版本中)是它会悄悄地无法显示每个接口的多个 IPv4 地址,这有时会变得非常混乱。)

    • 1

相关问题

  • 三台电脑,没有路由器/交换机怎么组网?

  • 用户使用 FileZilla 连接到 SFTP 服务器拒绝连接

  • NAT 后面的 NAT 如何工作(路由器的 NAT 和 ISP 的 NAT)?

  • Win10 1803:如何让移动热点成为专用网络?

  • nc如何识别服务名称

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