> 技术文档 > 两台电脑连接交换机,使用其中一台电脑的网络上网(NAT转发)

两台电脑连接交换机,使用其中一台电脑的网络上网(NAT转发)


场景

windows 电脑和 linux电脑连在同一台交换机上,linux电脑有通过无线网络。要实现Windows电脑通过交换机共享Linux电脑的无线网络上网,需将Linux设为网关并进行网络共享,步骤如下:

一、Linux电脑设置(网关配置)

  1. 开启IP转发‌
    编辑配置文件:
sudo vim /etc/sysctl.conf取消注释:net.ipv4.ip_forward = 1应用配置:sudo sysctl -p‌不行的话就直接重启电脑
  1. 设置 linux 有线接口静态IP‌(可选)
    我跳过了这一步,直接在系统设置里设置了 ip。
    例如分配192.168.2.5/24给有线网卡:
sudo ip addr add 192.168.2.5/24 dev enp5s0sudo ip link set enp5s0 up
  1. 配置NAT转发‌
    添加iptables规则(假设无线网卡为 wlx584120dbaca9 ,自动获取IP。有线网卡为 enp5s0 ,手动配置ip,例如配为 192.168.2.5):
依次执行:#清除现有规则(可选)sudo iptables -Fsudo iptables -t nat -F#启用NAT(将 enp5s0 的流量转发到 wlx584120dbaca9 )sudo iptables -t nat -A POSTROUTING -o wlx584120dbaca9 -j MASQUERADEsudo iptables -A FORWARD -i wlx584120dbaca9 -o enp5s0 -m state --state RELATED,ESTABLISHED -j ACCEPTsudo iptables -A FORWARD -i enp5s0 -o wlx584120dbaca9 -j ACCEPT#保存规则sudo apt install iptables-persistent -ysudo netfilter-persistent save
  1. 开启DHCP服务(可选,开启后 windows电脑可以不用设置固定ip,我跳过了这步)
sudo apt install isc-dhcp-server -ysudo vim /etc/dhcp/dhcpd.conf在文件中加入:subnet 192.168.2.0 netmask 255.255.255.0 {range 192.168.2.100 192.168.2.200;option routers 192.168.2.5; # linux有线接口ipoption domain-name-servers 8.8.8.8; #DNS服务器}保存后,启动服务sudo systemctl restart isc-dhcp-server

二、Windows电脑设置

  1. 有线网络配置静态IP‌(如果 linux 开启了 DHCP,则可改为自动获取 IP)

IP地址:192.168.2.6(与Linux同网段)
子网掩码:255.255.255.0
网关:192.168.2.5(指向Linux有线IP)
DNS:公共DNS 8.8.8.8 或运营商DNS‌

关闭防火墙测试‌
控制面板 → Windows Defender防火墙 → 启用/关闭防火墙(临时关闭验证连通性)‌

三、故障排除

开放Linux防火墙端口:
sudo ufw allow from 192.168.2.0/24 # 允许内网访问