Назад | Перейти на главную страницу

Сетевой мост QEMU для общедоступного IP

Я просто хочу, чтобы мои виртуальные машины QEMU имели общедоступный IP-адрес, чтобы я мог запускать несколько серверов на одной машине. Я прочитал много вики, руководств, руководств, веток форумов и всего, что связано с этим, но до сих пор не получил полезного ответа. Я уже знаю о мостах, и я сделал все, что делают большинство руководств.

1) Создайте мост с помощью iproute2 (скажем, br0)
2) Создайте интерфейс TAP (скажем, tap0)
3) Мост eth0 (в моем случае enp2s0) и tap0 к br0

Но единственное, что у меня есть (помимо головной боли), это заставить виртуальную машину распознаваться как другую машину во внутренней сети, но я хочу, чтобы внешняя сеть видела мою машину со своим собственным общедоступным IP-адресом, а не с тем же как и остальные физические машины, подключенные к роутеру.

Страницы, которые я просмотрел:
- https://wiki.archlinux.org/index.php/QEMU#Networking
- https://wiki.archlinux.org/index.php/Network_bridge
- KVM - Добавление общедоступного IP-адреса через мост
- http://blog.elastocloud.org/2015/07/qemukvm-bridged-network-with-tap.html
- https://wiki.qemu.org/Documentation/Networking
- http://nairobi-embedded.org/a_qemu_tap_networking_setup.html
- https://en.wikibooks.org/wiki/QEMU/Networking

Мои аргументы команд QEMU:

qemu-system-x86_64 \
    -monitor stdio \
    -soundhw ac97 \
    -k es \
    -machine accel=kvm \
    -m 2024 \
    -hda /mnt/hdd/Desarrollo_Eficiente_HDA.img \
    -boot once=c,menu=on \
    -net nic,vlan=0,macaddr=00:c6:cd:1a:5e:83,model=virtio \
    -net tap,vlan=0,ifname=tap0,script=no \
    -rtc base=localtime \

Другие выходы команд:

$ brctl show
bridge name     bridge id               STP enabled     interfaces
br0             8000.003067a647ca       no              enp2s0
                                                        tap0
$ ip address 
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 brd 127.255.255.255 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: enp2s0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast master br0 state UP group default qlen 1000
    link/ether 00:30:67:a6:47:ca brd ff:ff:ff:ff:ff:ff
    inet6 fe80::da85:a46d:3e50:2642/64 scope link 
       valid_lft forever preferred_lft forever
9: br0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default qlen 1000
    link/ether 00:30:67:a6:47:ca brd ff:ff:ff:ff:ff:ff
    inet 192.168.0.3/24 brd 192.168.0.255 scope global noprefixroute br0
       valid_lft forever preferred_lft forever
    inet 192.168.50.14/24 brd 192.168.50.255 scope global noprefixroute br0
       valid_lft forever preferred_lft forever
    inet6 fe80::230:67ff:fea6:47ca/64 scope link noprefixroute 
       valid_lft forever preferred_lft forever
10: tap0: <NO-CARRIER,BROADCAST,MULTICAST,PROMISC,UP> mtu 1500 qdisc pfifo_fast master br0 state DOWN group default qlen 100
    link/ether 16:51:80:cd:dd:6b brd ff:ff:ff:ff:ff:ff
    inet6 fe80::1451:80ff:fecd:dd6b/64 scope link 
       valid_lft forever preferred_lft forever

Информация о хост-системе:
- ОС: Parabola GNU / Linux-libre (на основе Arch)
- Архитектура: x86_64

Я что-то упустил? правило iptables? команда sysctl? Заранее спасибо за помощь.