Estou tentando criar uma ponte Ethernet com systemd-networkd para que convidados KVM possam acessar a rede. Estou no Debian 11 Bullseye, tentando criar a ponte "host1" no dispositivo físico "eno1".
root@debian-kvm:/etc/systemd/network# ls
20-wired.network host1.netdev host1.network uplink.network
root@debian-kvm:/etc/systemd/network# cat 20-wired.network
[Match]
Name=eno1
[Network]
DHCP=No
Address=192.168.1.57/24
Gateway=192.168.1.1
DNS=1.1.1.1
root@debian-kvm:/etc/systemd/network# cat host1.netdev
[Netdev]
Name=host1
Kind=bridge
root@debian-kvm:/etc/systemd/network# cat host1.network
[Match]
Name=host1
[Network]
Address=192.168.1.2/24
Gateway=192.168.1.1
DNS=1.1.1.1
root@debian-kvm:/etc/systemd/network# cat uplink.network
[Match]
Name=eno1
[Network]
Bridge=host1
No entanto, não funciona quando faço "systemctl restart systemd-networkd". eno1 está bem e mantém a conexão de rede, e posso executar ping em sites e endereços IP, mas a ponte host1 nunca aparece.
root@debian-kvm:/etc/systemd/network# networkctl
IDX LINK TYPE OPERATIONAL SETUP
1 lo loopback carrier unmanaged
2 eno1 ether routable configured
3 eno2 ether off unmanaged
4 eno3 ether off unmanaged
5 eno4 ether off unmanaged
root@debian-kvm:/etc/systemd/network# ip link
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT group default qlen 1000
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
2: eno1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP mode DEFAULT group default qlen 1000
link/ether b8:ca:3a:64:65:88 brd ff:ff:ff:ff:ff:ff
altname enp1s0f0
3: eno2: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN mode DEFAULT group default qlen 1000
link/ether b8:ca:3a:64:65:89 brd ff:ff:ff:ff:ff:ff
altname enp1s0f1
4: eno3: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN mode DEFAULT group default qlen 1000
link/ether b8:ca:3a:64:65:8a brd ff:ff:ff:ff:ff:ff
altname enp1s0f2
5: eno4: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN mode DEFAULT group default qlen 1000
link/ether b8:ca:3a:64:65:8b brd ff:ff:ff:ff:ff:ff
altname enp1s0f3
Pelo que posso dizer, deve funcionar. Os arquivos estão em /etc/systemd/network que tem prioridade mais alta, há um arquivo .netdev com sintaxe e nome corretos, há um arquivo uplink.network indicando que o pai é eno1 e há um arquivo host1.network que configura o IP, DNS, etc. mover host1.network para 25-wired.network também não ajuda, então não parecem ser os nomes dos arquivos.
Caso seja algo em /etc/network/interfaces, mas não acho que o systemd-networkd leia este arquivo:
root@debian-kvm:/etc/systemd/network# cat /etc/network/interfaces
# This file describes the network interfaces available on your system
# and how to activate them. For more information, see interfaces(5).
source /etc/network/interfaces.d/*
# The loopback network interface
auto lo
iface lo inet loopback
# The primary network interface
allow-hotplug eno1
iface eno1 inet manual
# KVM Host interface, use this to avoid conflicts, physical device is just for physical connection
iface host1 inet manual
# FreeBSD KVM bridge
#iface frbsd1 inet static
# bridge_ports eno1
# address 192.168.1.45
# broadcast 192.168.1.255
# netmask 255.255.255.0
# gateway 192.168.1.1
Eu sei que poderia simplesmente criar um script de inicialização para criar uma ponte a cada inicialização, mas isso é um pouco hackeado e quero resolver o problema de maneira sustentável.
O que está acontecendo aqui e como posso consertar para criar a ponte corretamente?
Responder1
Como wangkaibule mencionou nos comentários da pergunta, eu deveria ter colocado [NetDev] e não [Netdev].
Para qualquer pessoa em situações semelhantes, os arquivos de configuração do systemd diferenciam maiúsculas de minúsculas - certifique-se de que tudo esteja digitado corretamente com a caixa correta, ou não funcionará.