将从 VirtualBox 导出的虚拟机导入 libvirt 后,网络界面显示为ens3
. 是否可以调整域配置以使其看起来enp0s3
像在 VirtualBox 中一样?
一开始可能会认为是重新启动,而不是迁移,导致 systemd 以不同的方式枚举接口。但是,由于重启后源环境中的界面仍然存在enp0s3
,因此验证并非如此
虽然在虚拟机内部更新网络配置很简单,但最好在 vm 之外解决它。有不止一种迁移,它们有许多不同的口味。
我的目标为 libvirt (7.0.0-3) 的主机正在运行 Debian Bullseye,而 KVM 是使用的管理程序。
这个答案表明该p0
部分由总线号决定。此 systemd 源代码中的顶部评论权威地喊出了指向可预测接口名称的链接,声称目标是即使在硬件更改后也能稳定命名。我没有深入研究细节,试图了解这一切是如何实现的。我发现下面引用的是否包含的描述p0
不够详细,我无法理解:
- 包含固件/BIOS 的名称提供 PCI Express 热插拔插槽索引号(例如:ens1)
- 包含硬件连接器的物理/地理位置的名称(例如:enp2s0)
…回退到 3) 如果适用…
是什么使它适用?我明白所有的词,但不明白在哪里搜索。因此,相反,在缺乏充分理解的情况下尝试完成的有趣部分。如果在网络接口的原始XMLenp1s3
定义中编辑总线号,接口名称将变为.
--- ens3 2022-05-28 00:00:00 +0000
+++ enp1s3 2022-05-28 01:00:00 +0000
@@ -100,3 + 100,3 @@
<alias name='net0'/>
- <address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/>
+ <address type='pci' domain='0x0000' bus='0x01' slot='0x03' function='0x0'/>
</interface>
是什么导致 systemd 在 VirtualBox 下运行时选择策略 3,但在 libvirt 环境中运行时选择策略 2?是否可以将 libvirt 配置为使 systemd 包含总线编号,即使它为零?
我已经尝试了所有我能想到的选择。包括添加另一个接口,但最终只是处于混合命名的状态(策略 2 用于ens3
,策略 3 用于enp1s3
,这与命名稳定押韵很好)。也尝试选择所有可用类型的网卡,但没有成功。
在总线 0 上时,生成的网络接口名称取决于它是位于 PCI 总线上还是 PCIe 总线上。PCI NIC 主要以短
ens3
格式枚举,而 PCIe NIC 获得更长的enp0s3
名称。使用 udev 术语,短格式是ID_NET_NAME_SLOT,ID_NET_NAME_PATH是长格式。设置ID_NET_NAME_SLOT时,优先。问题中链接的源代码文件设置了这些值。
在 Linux 5.5 ( changelog ) 和 systemd 245 ( release notes ) 中引入了替代名称的概念,这意味着自 2019 年以来ID_NET_NAME_PATH已设置为
ip link
PCI NIC 上的替代名称(请参阅 )。如果您无法enp0s3
与ens3
.因此,除了仅查看您似乎已经了解其参数的接口配置之外,请确保您的域定义中存在类似以下内容(注意
e
模型中存在 an)并且您的 NIC 位于 PCIe 上公共汽车:并非所有机器类型都支持所有控制器,因此使用所需配置重新创建 VM 并再次导入可能是最简单的解决方案。
有人可能会推测,命名是有历史原因的。当预期只有一个 PCI 总线 0 并且所有 NIC 都位于同一总线上的不同插槽中时,包括总线号似乎无关紧要。
为了列出所有名称和替代名称
udevadm info -e
应该做的伎俩。