我在 Debian 12 系统上通过networking.service
和配置文件使用网络(如此处所示)。/etc/network/interfaces
问题
我添加了一个 GPU,重启后,计算机处于离线状态。这是一台没有显示器的 NAS,所以我必须连接一个屏幕和一个键盘。
我看到ip addr
报告了一个新的界面:enp3s0
。
问题:我的配置中/etc/network/interfaces
仅提到enp2s0
:
# This file describes the network interfaces available on your system
# and how to activate them. For more information, see interfaces(5).
# The loopback network interface
auto lo
iface lo inet loopback
# The primary network interface
allow-hotplug enp2s0
iface enp2s0 inet dhcp
临时解决方案
我必须将其替换enp2s0
并enp3s0
运行systemctl restart networking
才能恢复网络,而且它有效。
如果有一天我移除 GPU 或添加 PCI-Express 设备,网络接口的名称可能会再次改变,服务器将离线。
因此我修改了conf文件以便管理enp2s0
或enp3s0
:
# The primary network interface
# without GPU
allow-hotplug enp2s0
iface enp2s0 inet dhcp
# with GPU
allow-hotplug enp3s0
iface enp3s0 inet dhcp
最终的解决方案?
对可能存在或不存在的接口声明 conf 是否安全?有没有更简洁的方法?
更简洁的解决方案之一是禁用可预测的接口名称。如果您的系统上只有一个接口,它将始终是
eth0
。另一种选择是先通过 MAC 地址识别接口,然后重命名接口。这在同一文档中进行了描述;例如,给定一个具有 MAC 地址的接口
52:54:00:bb:a4:80
,我可以将以下内容放入/etc/systemd/network/10-lan0.link
:现在,无论何时系统启动,具有该 MAC 地址的接口都将被命名为
lan0
。然后我会
/etc/network/interfaces
这样写:由于接口由其 MAC 地址标识,因此无论您在系统中安装了什么其他卡,它都可以工作。
我认为最初的发帖人的解决方案,重复额外的接口名称,已经是最好的了。从需求(无头服务器、NAS、有限的硬件更改)开始,原因如下:
关注需求:
需求:在任何接口上启用 DHCP并且不要被锁定,这还包括多年来幸存的软件更新。
确保任何 NIC 都启用 DHCP 的最小、最简单的方法是CATCHALL 接口命名
systemd
,无需任何复杂性udev
这样,我们就避免了
systemd
重命名接口的规则和udev
规则,这两者都是动态的、可编程的和复杂的,但不会为这种用例带来任何好处,并会产生额外的故障点:systemd
根据 mac 地址或通配符匹配进行重命名效果很好,但如果initrd
不重新生成,该规则可能会被忽略。您还需要修改 /etc/network/interfaces 以匹配规则。udev
也可以做同样的事情,通过 MAC 地址或通配符识别 NIC,但随后需要脚本来配置接口,例如interface=$1;ip link set dev $interface up;dhclient $interface
在 Debian 文档中,网络下的CATCHALL INTERFACE NAMING被提及,特别是配置 #Safety_nets 。它被认为是一种可以接受的增加系统健壮性的方法,但极端情况仍然会让你感到惊讶
一个例子
从您的示例开始,为合理数量的可能名称创建额外的接口记录:
可供考虑的替代方案,以及对每种方案的意见:
工作,但与系统升级和其他复杂性联系过于紧密
systemd
链接规则(如上所述)udev
规则(如上所述)有点黑客风格,应该可以工作,但未经测试,比“顶级”解决方案更有优势(捕获所有接口名称)
/etc/networking/interfaces
例如通配符allow-hotplug enp* / iface enp* inet dhcp
效果不错,但可能不值得
netplan
,来自netplan.io
包,可以控制接口,匹配名称,并委托给其他系统,如 NetworkManager,但默认为systemd
此示例配置匹配名称,然后告知
systemd
(通过networkd
渲染器)启用 dhcp。运行sudo netplan apply
network-manager
包,通过nmcli
或nmtui
如果您想要 TUI 进行控制。通常是桌面的 GUI 工具,它在内部使用易于使用的 yaml 文件。示例配置,注意路径,并记得运行
sudo systemctl restart NetworkManager