[QEMU網絡配置] 通過網橋使宿主機和虛擬機互通網絡

更新3 另一種更為簡單的方式(缺點是:局域網其他機器無法訪問該虛擬機)

宿主需要有samba/配置好samba的用戶名和共享目錄
smb.conf

[share]
path=/home/work/Myproj/vms/share_dir
public=no
guest ok=yes
writable=yes
browseable=yes
valid users=samba1

宿主機操作

sudo useradd samba1
sudo passwd samba1
sudo smbpasswd -a samba1
測試下:
smbclient //127.0.0.1/share -U samba1%123

虛擬機啟動腳本

qemu-system-x86_64 --enable-kvm -m 2048 -smp 2 -hda vm1.raw \
-netdev user,id=ndev.0,hostfwd=tcp::5555-:22 \
-device e1000,netdev=ndev.0 \
-smb /home/work/Myproj/vms/share_dir

宿主機訪問該虛擬機
ssh 127.0.0.1 -p 5555

虛擬機訪問該共享目錄
smbclient -L //10.0.2.2 -U samba1%123

虛擬機掛載該目錄
sudo mount -t cifs //10.0.2.2/share ~/mnt_host -o username=samba1,password=123

更新: 2個issue

    1. 宿主機缺失2個網卡腳本/etc/qemu-ifdown /etc/qemu-ifup,自己寫個就行.
[work  ~  ]$cat /etc/qemu-ifup
#!/bin/bash
#This is a qemu-ifup script for bridging.
#You can use it when starting a KVM guest with bridge mode network.
#set your bridge name
switch=br0
if [ -n "$1" ]; then
    #create a TAP interface; qemu will handle it automatically.
    #tunctl -u $(whoami) -t $1
    #start up the TAP interface
    ip link set $1 up
    sleep 1
    #add TAP interface to the bridge
    brctl addif ${switch} $1
    exit 0
else
    echo "Error: no interface specified"
    exit 1
fi
[work  ~  ]$cat /etc/qemu-ifdown 
#! /bin/sh  
switch=br0  
brctl delif ${switch} $1
    1. 同一局域網多個虛擬機有可能產生MAC沖突,造成ssh沒有響應.
      qemu啟動腳本中修改MAC地址即可.
-net nic,macaddr=xx:xx:xx:xx:xx:xx

宿主機操作

  • 內核支持:
Device driver --> Network device support -->Universal TUN/TAP device driver support
  • 用戶態軟件:
apt-get install uml-utilities bridge-utils
  • 修改網絡配置:增加tap0br0
$cat /etc/network/interfaces
# interfaces(5) file used by ifup(8) and ifdown(8)
auto lo
iface lo inet loopback
+auto tap0
+iface tap0 inet manual
+up ifconfig $IFACE 0.0.0.0 up
+down ifconfig $IFACE down
+tunctl_user nmt
+auto br0
+iface br0 inet dhcp
+bridge_ports all tap0
  • 啟動這倆網絡設備
sudo /sbin/ifup tap0
sudo /sbin/ifup br0

*啟動qemu

sudo qemu-system-x86_64 --enable-kvm -m 4G -smp 2 -hda ./VMs/vm1.raw -net nic -net tap

至于虛擬機的網路配置

(啥也不做,都是默認配置)


  • 鏈接成功
$ssh work@192.168.1.102
work@192.168.1.102's password: 
Welcome to Ubuntu 14.04.4 LTS (GNU/Linux 4.2.0-27-generic x86_64)

 * Documentation:  https://help.ubuntu.com/

  System information as of Wed Dec 14 20:28:01 CST 2016

  System load:  0.0               Processes:           84
  Usage of /:   6.7% of 18.33GB   Users logged in:     1
  Memory usage: 1%                IP address for eth0: 192.168.1.102
  Swap usage:   0%

  Graph this data and manage this system at:
    https://landscape.canonical.com/

New release '16.04.1 LTS' available.
Run 'do-release-upgrade' to upgrade to it.

Last login: Wed Dec 14 20:28:01 2016 from 192.168.1.176
work@vm1:~$ ifconfig
eth0      Link encap:Ethernet  HWaddr 52:54:00:12:34:56  
          inet addr:192.168.1.102  Bcast:192.168.1.255  Mask:255.255.255.0
          inet6 addr: fe80::5054:ff:fe12:3456/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:168 errors:0 dropped:0 overruns:0 frame:0
          TX packets:139 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:22868 (22.8 KB)  TX bytes:21206 (21.2 KB)

lo        Link encap:Local Loopback  
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:65536  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0 
          RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)

work@vm1:~$ 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).

# The loopback network interface
auto lo
iface lo inet loopback

# The primary network interface
auto eth0
iface eth0 inet dhcp
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容