一、问题现象
-
Kali 虚拟机每次重启后无法自动联网
-
需要手动执行 sudo dhclient eth0才能获取 IP
-
配置静态 IP 后发现网关不通(Destination Host Unreachable)
二、根本原因
|----------|---------------------------------------------------------------|
| 问题层级 | 具体原因 |
| IP地址不匹配 | 配置的IP与VMWare实际网络模式不匹配 |
| 网络模式混乱 | NAT模式和桥接模式的网段混用 |
| 服务冲突 | /etc/network/interfaces与NetworkManager同事管理网卡 |
| 配置文件格式冲突 | dns-nameservers写成了dns- nameservers(名称内存在空格) |
| 缩进错误 | interfaces文件内的address、gateway等缺少必要缩进,且address和gateway之间的网段不匹配 |
三、解决办法
阶段1:诊断确认
bash
ip a show eth0 # 查看当前 IP
ping 8.8.8.8 # 测试外网连通性
ping baidu.com # 测试 DNS 解析
nmcli device status # 查看 NetworkManager 状态
ip route show default # 查看默认网关
阶段二:尝试传统解决办法
bash
# 方法1:修改 NetworkManager 配置
sudo nano /etc/NetworkManager/NetworkManager.conf
# 将 managed=false 改为 managed=true
# 方法2:修改 interfaces 文件配置静态 IP(格式错误导致失败)
sudo nano /etc/network/interfaces
ps:若失败,失败原因可能如下:
-
配置文件语法错误(缩进、拼写)
-
IP 网段与 VMware 网络模式不匹配
-
/etc/network/interfaces与 NetworkManager 冲突
阶段三:不到万不得已的情况下
核心思路:让NetworkManager完全接管网络配置,放弃/etc/network/interfaces
bash
# 清空 interfaces 文件,只保留回环接口
sudo tee /etc/network/interfaces << 'EOF'
auto lo
iface lo inet loopback
EOF
# 让 NetworkManager 管理对应的网卡
sudo nmcli device set eth0 managed yes
# 删除旧连接,创建新连接
sudo nmcli con delete "Wired connection 1" 2>/dev/null
sudo nmcli con add con-name "Bridged-Static" type ethernet ifname eth0
# 配置静态 IP(桥接模式)
sudo nmcli con mod "Bridged-Static" ipv4.addresses 10.42.0.100/24
sudo nmcli con mod "Bridged-Static" ipv4.gateway 10.42.0.1
sudo nmcli con mod "Bridged-Static" ipv4.dns "223.5.5.5 114.114.114.114"
sudo nmcli con mod "Bridged-Static" ipv4.method manual
# 启用连接
sudo nmcli con up "Bridged-Static"
# 设置开机自动连接
sudo nmcli con mod "Bridged-Static" autoconnect yes
四、关键命令速查表:
|--------------------------------------|------------------------|
| 命令 | 用途 |
| ip a show 网卡名称 | 查询对应网卡的IP地址 |
| ping 8.8.8.8 | 测试外网连通性 |
| ping baidu.com | 测试DNS解析 |
| ip route show | 查看路由表/网关 |
| nmcli device status | 查看网卡管理状态 |
| nmcli device set 网卡名称 managed yes/no | 设置NetworkManager是否管理网卡 |
| nmcli con show | 查看所有网络连接 |
| nmcli con up/down <连接名> | 启用/停用网络连接 |
| sudo systemctl restart networking | 重启网络服务 |
| cat /etc/resolv.conf | 查看DNS配置 |
五、NAT 模式 vs 桥接模式
| 模式 | 特点 | 适用场景 | 网段示例 |
|---|---|---|---|
| NAT | 虚拟机通过宿主机上网,与宿主机不同网段 | 普通上网、更新系统 | 192.168.115.x |
| 桥接 | 虚拟机与宿主机在同一局域网,平等设备 | 渗透测试、内网扫描 | 10.42.0.x |
六、经验教训
-
NetworkManager 更可靠 :现代 Linux 桌面版建议用 NetworkManager 而非传统
interfaces文件 -
格式严格:Linux 配置文件对空格、缩进、拼写极度敏感
-
网段必须匹配:静态 IP 必须与 VMware 网络模式的实际网段一致
-
先诊断后动手 :
ping网关是定位问题的关键一步 -
权限意识 :修改系统配置必须用
sudo
七、后续维护
如果物理机网络环境变化(如换了 Wi-Fi),只需更新 NetworkManager 配置:
bash
sudo nmcli con mod "Bridged-Static" ipv4.addresses <新IP>/24
sudo nmcli con mod "Bridged-Static" ipv4.gateway <新网关>
sudo nmcli con down "Bridged-Static" && sudo nmcli con up "Bridged-Static"