ブリッジネットワークでqemu/kvmを使用しています。ホストマシンには、IPなしの「vnetX」ネットワークインターフェイスがいくつかあります。どのvnetXが仮想マシンに属しているかを知る方法を探しています。
これらのインターフェイスのMACアドレス値を仮想マシンのMAC(またはそれらを定義するXML)と一致させようとしましたが、一致しません。
ブリッジに属するvnetインターフェースを表示するbrctl showがありますが、これは有用な情報ではありません。
その関係を知る方法はありますか?どうも!!
これはどうですか(vnet13
の例):
$ VNET=vnet13; for vm in $(virsh list | grep running | awk '{print $2}'); do virsh dumpxml $vm|grep -q "$VNET" && echo $vm; done
ここでは、virsh dumpxml
を使用して、VMに関する動的プロパティを表示しています。これは、VMの静的XML定義では使用できません。 VMがそのような動的プロパティであるvnetX
インターフェースが接続されています。VMのMACアドレスについても同様です。
virsh dumpxml $domain
をお試しください。次のようなものが表示されます。
<interface type='network'>
<mac address='52:54:00:9d:9d:10'/>
<source network='default'/>
<target dev='vnet1'/>
<model type='e1000'/>
<alias name='net1'/>
<address type='pci' domain='0x0000' bus='0x00' slot='0x0c' function='0x0'/>
alias name
はqemu-kvmコマンドラインで使用されるものであるため、この例からps -ef |grep qemu|grep net1
を実行すると、このインターフェイスで使用される実際のコマンド構文が表示されます。
上記のすべてのソリューションは、VMがlibvirtによって管理されていることを前提としています。それなしでQEMU VMを実行することは十分に可能です。その場合、virshを使用したり、XMLを調べて答えを見つけることはできません。
「生の」コマンドラインからQEMU VMを実行する場合:
tcpdump -i tap0 -f 'icmp'(興味のあるいずれかのタップインターフェイスに置き換えます)
各候補をpingしますVMトレースにパケットが表示されるまで。ICMPパケットが表示されたときにトレースしているインターフェイスが探しているものです!
逆に、特定のVMに対してpingを開始してから、1つの「ライトアップ」されるまで各タップインターフェイスを順番にtcpdumpすることができます。VMタップインターフェイスに一致するか、VMに一致するタップインターフェイス。
vnetX
インターフェイスのMACアドレスは、ゲストではなくホストに属しています。 brctl showmacs br0
には、ブリッジによって検出されたMACが表示されますが、ポート番号とbrctl show
のインターフェースのリストを相互参照する必要があります。
ArpキャッシュからVMにIPアドレスを一致させる
# vm mac address list
for vm in $(virsh list | grep running | awk '{print $2}'); do \
echo -n "$vm "; \
virsh dumpxml $vm| grep -oP "52:54:[\da-f:]+" ;
done > vm_mac.list
# vm ip list
arp -i virbr0 | grep '52:' | while read addr ; do \
ip=$(echo $addr | awk '{print $1}'); \
mac=$(echo $addr | awk '{print $3}'); \
vm=$(grep "$mac" vm_mac.list | awk '{print $1}'); \
echo "$vm $ip $mac"; \
done | sort
出力例:
vm66 192.168.191.112 52:54:00:ab:e8:cb
vm67 192.168.191.207 52:54:00:88:66:e7
vm67 192.168.191.241 52:54:00:88:66:e7
vm68 192.168.191.197 52:54:00:c5:e1:30
vm69 192.168.191.254 52:54:00:b6:f6:0f
vm70 192.168.191.232 52:54:00:08:7f:49
vm71 192.168.191.113 52:54:00:e7:6f:2b
for vm in $(virsh list --state-running --name); do \
echo $vm; \
virsh domifaddr $vm; \
done
出力例:
client1
Nombre dirección MAC Protocol Address
------------------------------------------------------------------------------
vnet2 52:54:00:2c:7a:f0 ipv4 192.168.122.63/24
@daff応答に基づく:
for vm in $(virsh list | grep running | awk '{print $2}'); do echo "$vm: " && virsh dumpxml $vm | grep "vnet" | sed 's/[^'']*''\([^'']*\)''[^'']*/\t\1/g'; done
出力例:
vm1:
vnet0
vm2:
vnet1
vm3:
vnet2
vm4:
vnet3
vnet4
vm5:
vnet5