Я использую Debian wheezy с XEN 4.1. У меня есть два сетевых моста xenbr0 и xenbr1.
xenbr0 связан с real-eth0-nic, поэтому domU могут общаться с внешним миром, что отлично работает.
xenbr1 был задуман как внутренний сетевой мост для связи между domU и dom0.
Проблема в xenbr1, и я не знаю почему. DomU успешно подключены к xenbr1, потому что я могу пинговать между domU. Так что мост каким-то образом работает, но трафик к или от xenbr1 dom0 невозможен.
Моя настройка xenbr1 в /etc/network/interfaces:
auto xenbr1
iface xenbr1 inet static
pre-up brctl addbr $IFACE
up ip link set $IFACE up
post-down brctl delbr $IFACE
down ip link set $IFACE down
address 10.0.0.1
netmask 255.255.255.0
hwaddress ether MAC
brctl шоу:
bridge name bridge id STP enabled interfaces
xenbr0 8000.mac no eth0
vif1.0
vif2.0
xenbr1 8000.mac no vif1.1
vif2.1
Сетевые соединения:
dom0
xenbr1 - 10.0.0.1
/ \
/ \
domU-1 domU-2
vif1.1 - 10.0.0.2 vif2.1 - 10.0.0.3
domU-1 может пинговать domU-2 и наоборот.
dom0 не может связаться ни с одним domU, а domU не могут связаться с dom0.Думаю, что-то заблокировано в dom0.
Первой моей мыслью было, что у меня проблема с iptables, но, похоже, xen создал необходимые правила:
-P INPUT ACCEPT
-P FORWARD ACCEPT
-P OUTPUT ACCEPT
-A FORWARD -m physdev --physdev-out vif2.1 --physdev-is-bridged -j ACCEPT
-A FORWARD -m physdev --physdev-in vif2.1 --physdev-is-bridged -j ACCEPT
-A FORWARD -m physdev --physdev-out vif2.0 --physdev-is-bridged -j ACCEPT
-A FORWARD -m physdev --physdev-in vif2.0 --physdev-is-bridged -j ACCEPT
-A FORWARD -m physdev --physdev-out vif1.1 --physdev-is-bridged -j ACCEPT
-A FORWARD -m physdev --physdev-in vif1.1 --physdev-is-bridged -j ACCEPT
-A FORWARD -m physdev --physdev-out vif1.0 --physdev-is-bridged -j ACCEPT
-A FORWARD -m physdev --physdev-in vif1.0 --physdev-is-bridged -j ACCEPT
Надеюсь, кто-нибудь сможет мне помочь или подскажет, где искать.
решение1
Я полагаю, это потому, что вам на самом деле нужен интерфейс, отличный от моста на Lonux dom0, чтобы трафик действительно достиг dom0. Мост — это просто мост, и он не предоставляет интерфейс в dom0. Вы можете попробовать настроить фиктивный интерфейс в dom0 и добавить его к мосту, или, возможно, интерфейс tap. Я не уверен, что это то, что происходит, но это определенно стоит попробовать.