05-LPB3568针对不同网段实现UDP通信

针对不同网段实现UDP通信

注意事项:两台电脑不要连wifi,需要关闭防火墙!

为了不断网也能通,PCA和PCB电脑必须同时**在各自电脑上执行以下操作:

第一步:PCA(192 电脑)的操作

继续保留你刚才那条命令,确保去 172 的路是对的:

DOS

python 复制代码
route add 172.20.114.0 mask 255.255.255.0 192.168.16.254

第二步:PCB(172 电脑)的操作

他必须在他的电脑上开管理员权限运行:

DOS

python 复制代码
route add 192.168.16.0 mask 255.255.255.0 172.20.114.254

注意: 这里的 172.20.114.254 是 LPB3568 的 eth1 地址。这样他回包时,数据才会顺着 LPB3568 爬回你这边。

  1. 准备工作 & 拓扑结构
    假设规划如下:
    ● 192网段: 192.168.16.254
    ● 172网段: 172.20.144.254
    物理连接:
  2. PC A (192电脑) 用网线插在 LPB3568 的 ETH0 口。
  3. PC B (172电脑) 用网线插在 LPB3568 的 ETH1 口。
    第一步:配置 LPB3568 (作为网关)
    你需要通过串口或者调试口登录到 LPB3568 的 Linux 终端。
    (1) 清除旧 IP (防止干扰)
    先看看当前 IP,如果有 DHCP 获取的乱七八糟的 IP,建议先删掉(或者直接覆盖)。
bash 复制代码
sudo ip addr flush dev eth0
sudo ip addr flush dev eth1

(2) 配置静态 IP (充当两边的网关)

我们将 eth0 设为 192 网段的网关,eth1 设为 172 网段的网关。

  1. 给 eth0 添加一个连接配置,名字叫 'static-eth0'
python 复制代码
sudo nmcli con add type ethernet con-name static-eth0 ifname eth0

(3) 设置静态 IP 和网关 (注意:这里不需要设网关,因为它是网关本身)

python 复制代码
sudo nmcli con modify static-eth0 ipv4.addresses 192.168.16.254/24 ipv4.method manual

(4) 启动这个连接 (这一步会真正应用 IP)

python 复制代码
sudo nmcli con up static-eth0
  1. 建立 eth1 的静态连接配置
python 复制代码
sudo nmcli con add type ethernet con-name static-eth1 ifname eth1
  1. 设置 eth1 的 IP 为
python 复制代码
sudo nmcli con modify static-eth1 ipv4.addresses 172.20.114.254/24 ipv4.method manual
  1. 启用配置(这一步执行后,IP 就会永久生效)
python 复制代码
sudo nmcli con up static-eth1
  1. 开启路由转发 (最关键的一步)
    默认 Linux 是不转发包的,要把开关打开。
python 复制代码
sudo nano /etc/sysctl.conf

#net.ipv4.ip_forward=1

去掉注释,永久生效

(注意:这只是临时生效,重启板子会失效。想永久生效去改 /etc/sysctl.conf)

  1. 关闭防火墙 (防止 Ping 不通)

为了调试方便,先把板子上的防火墙策略清空,允许所有通过。

如果是 iptables

python 复制代码
sudo iptables \-F
sudo iptables \-X

如果有 firewalld

python 复制代码
sudo systemctl stop firewalld

第二步:配置 PC A (192 电脑)

假设这台电脑是 Windows:

  1. 打开 网络连接 -> 以太网属性 -> IPv4。
  2. IP地址: 192.168.16.25(只要不是 .254就行)
  3. 子网掩码: 255.255.255.0
  4. 默认网关: 192.168.16.254 (必须填 LPB3568 的 eth0 地址)
  5. 点击确定。
    第三步:配置 PC B (172 电脑)
    假设这台电脑也是 Windows:
  6. 打开 网络连接 -> 以太网属性 -> IPv4。
  7. IP地址:172.20.144.25
  8. 子网掩码: 255.255.255.0
  9. 默认网关: 172.20.144.254 (必须填 LPB3568 的 eth1 地址)
  10. 重要:关闭 Windows 防火墙。Windows 默认会拦截公用网络的 Ping 和 UDP 入站,为了测试请暂时关闭 PC B 的防火墙。
    第四步:测试连通性 (Ping)
    先别急着测 UDP,先测路通不通。
  11. 在 PC A (192.168.16.25) 上打开 CMD。
  12. 输入:ping 172.20.144.25
  13. 如果能 Ping 通,说明 LPB3568 的路由转发已经成功了!
    (如果 Ping 不通:检查 PC B 的防火墙是否关闭,检查 LPB3568 的 ip_forward 是否为 1)
    第五步:UDP 通信测试
    既然路通了,我们用简单的工具来发 UDP。你是做研发的,我推荐直接用 Python 脚本测,最准。
    场景:PC A 发送,PC B 接收
  14. 在 PC B (接收端 172.20.144.25) 上运行接收脚本:
    创建一个 udp_server.py:
python 复制代码
import socket

\# 绑定本机的所有 IP,监听 8888 端口
sock \= socket.socket(socket.AF\_INET, socket.SOCK\_DGRAM)
sock.bind(('0.0.0.0', 8888))

print("等待接收 UDP 数据...")
while True:
    data, addr\= sock.recvfrom(1024)
    print(f"收到来自 {addr} 的消息: {data.decode()}")
  1. 在 PC A (发送端 192.168.16.25) 上运行发送脚本:
    创建一个 udp_client.py:
python 复制代码
import socket

\# 目标是 PC B 的 IP
TARGET\_IP \= '172.16.20.2'
TARGET\_PORT \= 8888

sock \= socket.socket(socket.AF\_INET, socket.SOCK\_DGRAM)

while True:
    msg\= input("输入要发送的内容: ")
    sock.sendto(msg.encode(), (TARGET\_IP, TARGET\_PORT))
    print("发送成功")

结果:

在 PC A 输入文字,PC B 应该能立马显示出来。

总结 LPB3568 在这里做的事:

  1. PC A 把包发给网关 (LPB eth0)。
  2. LPB 收到包,查路由表,发现目标是 172 网段。
  3. LPB 把包从 eth1 转出去。
  4. PC B 收到包。
    这就是最标准的三层路由模型。
相关推荐
The Straggling Crow1 小时前
Network
网络
yyuuuzz1 小时前
独立站的技术基础与常见运维问题
大数据·运维·服务器·网络·数据库·aws
Oll Correct4 小时前
实验二十九:TCP的运输连接管理
网络·笔记
Cheng小攸6 小时前
综合实验2
网络·windows
Soari7 小时前
SSH 主机密钥冲突
运维·网络·ssh
且听风吟_xincell8 小时前
用 TypeScript 从零写一个 TCP 聊天室(上)—— 网络编程入门实战
网络·tcp/ip·typescript
万法若空10 小时前
Libevent C语言开发完全教程:从入门到实战
c语言·网络
鹿鸣天涯10 小时前
kali 2026.1 vmware虚拟机内看不见鼠标处理方法
网络·计算机外设
蜡笔婧萱11 小时前
网络服务综合大实验--包含NFS服务器,Web服务器,DNS域名服务器
linux·服务器·网络
汽车仪器仪表相关领域11 小时前
Kvaser Hybrid CAN/LIN 单通道三合一总线分析仪:高性价比CAN FD/LIN集成测试利器
运维·服务器·网络·数据挖掘·数据分析·单元测试·集成测试