Виртуальный интерфейс (veth) не работает в libvirtd/virt-manager для моста
TL; DR?
"в большинстве конфигураций macvtap не работает для связи хоста с гостевой сетью"
У меня есть настройка virt-manager на Intel NuC с одним Ethernet.
У меня также есть его установка на супермикросервере с Ethernet x4, который соединен мостом (nm-bridge), где используется veth для размещения устройства macvtap, где моя виртуальная машина может видеть хост.
Я читал, что мне нужно установить мост здесь (что я и сделал, назначив свой единственный eno1 на nm-bridge)
но не упоминается, как правильно настроить veth-устройства.
Я нашел здесь руководство о том, как это сделать
но в данном примере используются пространства имен (netns). Однако на другом хосте (который использует мосты + виртуальные интерфейсы Ethernet от этого моста) у меня нет netns (то есть списка ip netns), и ни одно из моих устройств vnet (tun устройства) или veth не имеет набора ip.
Я пробовал (исходя из этого: https://superuser.com/questions/764986/howto-setup-a-veth-virtual-network)
ip link add dev veth1 type veth
ip link set veth1 master nm-bridge
ip link set veth0 master nm-bridge
ip link set dev veth0 up
ip link set dev veth1 up
В основном я пытаюсь заставить свою виртуальную машину разговаривать с моим хостом
1 ответ
Нашел решение
#!/bin/sh
# Let host and guests talk to each other over macvlan.
# Configures a macvlan interface on the hypervisor.
# Run this on the hypervisor (e.g. in /etc/rc.local)
# Made for IPv4; need modification for IPv6.
# Meant for a simple network setup with only eth0,
# and a static (manual) ip config.
# Evert Mouw, 2013. Slightly modified in 2020.
HWLINK=enp5s0
MACVLN=macvlan0
TESTHOST=www.google.com
# ------------
# test if interface already exists
# ------------
if ip link show | grep "$MACVLN@$HWLINK" > /dev/null
then
echo "Link $MACVLN already exists on $HWLINK."
exit
fi
# ------------
# wait for network availability
# ------------
while ! ping -q -c 1 $TESTHOST > /dev/null
do
echo "$0: Cannot ping $TESTHOST, waiting another 5 seconds."
sleep 5
done
# ------------
# get network config
# ------------
IP=$(ip address show dev $HWLINK | grep "inet " | awk '{print $2}')
NETWORK=$(ip -o route | grep $HWLINK | grep -v default | awk '{print $1}')
GATEWAY=$(ip -o route | grep default | awk '{print $3}')
# ------------
# setting up $MACVLN interface
# ------------
ip link add $MACVLN link $HWLINK type macvlan mode bridge
ip address add $IP dev $MACVLN
ip link set dev $MACVLN up
# ------------
# routing table
# ------------
# empty routes
ip route flush dev $HWLINK
ip route flush dev $MACVLN
# add routes
ip route add $NETWORK dev $MACVLN metric 0
# add the default gateway
ip route add default via $GATEWAY