[qemu] qemu舊的net參數已經再也不可用了,新的這樣用。

 

老的命令:html

/root/BUILD_qemu/bin/qemu-system-x86_64 -enable-kvm \
    -m 2G \
    -cpu Nehalem -smp cores=4,threads=2,sockets=2 \
        -numa node,mem=1G,cpus=0-8,nodeid=0 \
        -numa node,mem=1G,cpus=9-15,nodeid=1 \
    -display vnc=0.0.0.0:1 \
    -net nic,vlan=1,model=virtio,macaddr='00:00:00:01:00:01' \
    -net tap,vlan=1,ifname=tap-int,script=no,downscript=no \
    -device virtio-net-pci,netdev=dev1,macaddr='00:00:00:01:00:02',vectors=32,mq=on \
    -netdev tap,ifname=tap-0,id=dev1,script=no,downscript=no,vhost=on,queues=16 \
    -drive file=disk.img,if=virtio \
    -cdrom /root/CentOS-7-x86_64-DVD-1511.iso \
    -boot order=c \

在qemu-2.11-0 會報錯以下:node

qemu-system-x86_64: -net nic,vlan=1,model=virtio,macaddr=00:00:00:01:00:01: 'vlan' is deprecated. Please use 'netdev' instead.

 

詳細用法:https://qemu.weilnetz.de/doc/qemu-doc.html#Network-optionslinux

摘要:git

-nic [tap|bridge|user|l2tpv3|vde|netmap|vhost-user|socket][,...][,mac=macaddr][,model=mn]
This option is a shortcut for configuring both the on-board (default) guest NIC hardware and the host network backend in one go. 
The host backend options are the same as with the corresponding -netdev options below. The guest NIC model can be set with model=modelname.
Use model=help to list the available device types. The hardware MAC address can be set with mac=macaddr. The following two example do exactly the same, to show how -nic can be used to shorten the command line length (note that the e1000 is
the default on i386, so the model=e1000 parameter could even be omitted here, too): qemu-system-i386 -netdev user,id=n1,ipv6=off -device e1000,netdev=n1,mac=52:54:98:76:54:32 qemu-system-i386 -nic user,ipv6=off,model=e1000,mac=52:54:98:76:54:32

簡單解釋:api

兩個方法:app

  A,用 -netdev和-device配合,-device須要志明model和mac,已經netdev的名字(這裏是n1)是兩個配置鏈接起來。socket

    全部可選的參數見:ui

[root@D128 j]# /root/BUILD_qemu/bin/qemu-system-x86_64 -device help

     不一樣的設備參數不一樣,須要查詢詳細的選項,如e1000egoogle

[root@D128 j]# /root/BUILD_qemu/bin/qemu-system-x86_64 -device e1000e,help
e1000e.rombar=uint32
e1000e.disable_vnet_hdr=uint8 (Do not use virtio headers, perform SW offloads emulation instead)
e1000e.x-pcie-lnksta-dllla=bool (on/off)
e1000e.bootindex=int32
e1000e.multifunction=bool (on/off)
e1000e.romfile=str
e1000e.vlan=int32 (Integer VLAN id to connect to)
e1000e.command_serr_enable=bool (on/off)
e1000e.x-pcie-extcap-init=bool (on/off)
e1000e.addr=int32 (Slot and optional function number, example: 06.0 or 06)
e1000e.mac=str (Ethernet 6-byte MAC Address, example: 52:54:00:12:34:56)
e1000e.netdev=str (ID of a netdev to use as a backend)
e1000e.subsys_ven=uint16 (PCI device Subsystem Vendor ID)
e1000e.subsys=uint16 (PCI device Subsystem ID)

 

  B, 使用簡化的命令,-nic,功能同A。一樣須要指明model和mac。可選參數見:spa

[root@D128 j]# /root/BUILD_qemu/bin/qemu-system-x86_64 -nic model=help
qemu: Supported NIC models: e1000,e1000-82544gc,e1000-82545em,e1000e,i82550,i82551,i82557a,i82557b,i82557c,i82558a,i82558b,i82559a,i82559b,i82559c,
i82559er,i82562,i82801,ne2k_pci,pcnet,rocker,rtl8139,virtio-net-pci,vmxnet3 [root@D128 j]#

 

改過以後的啓動腳本:

/root/BUILD_qemu/bin/qemu-system-x86_64 -enable-kvm \
    -m 2G \
    -cpu Nehalem -smp cores=4,threads=2,sockets=2 \
        -numa node,mem=1G,cpus=0-8,nodeid=0 \
        -numa node,mem=1G,cpus=9-15,nodeid=1 \
    -display vnc=0.0.0.0:1 \
    -device e1000e,netdev=dev0,mac='00:00:00:01:00:01' \
    -netdev tap,ifname=tap-int,id=dev0,script=no,downscript=no,vhost=on \
    -device virtio-net-pci,netdev=dev1,mac='00:00:00:01:00:02',vectors=32,mq=on \
    -netdev tap,ifname=tap-0,id=dev1,script=no,downscript=no,vhost=on,queues=16 \
    -drive file=disk.img,if=virtio \
    -cdrom /root/CentOS-7-x86_64-DVD-1511.iso \
    -boot order=c \
    &

 

-----------------------------------------------------------------------------------------------------------------------

依照以下步驟。雖然能編譯,也能用,可是用起來仍是有問題的,不清楚爲何。

好比: 1. kvm很差用,運行起來特別慢。2。 舊的image沒法boot。

-----------------  update ---------------

改了些編譯參數,再編譯:

[root@D128 qemu-2.12.0-rc3]# yum install ncurses-devel
[root@D128 qemu-2.12.0-rc3]# ./configure --enable-curses --enable-vhost-user --prefix=/root/BUILD_qemu/ --target-list=x86_64-softmmu --disable-gtk --enable-docs --enable-numa --enable-kvm --enable-modules --enable-system --enable-linux-user

支持了什麼,configure的輸出裏都會打印出來。

可能會形成影響的參數包括

--enable-modules --enable-system --enable-linux-user

以上的參數,對效果影響沒有區別。。。。

 

跟其餘同事又找了一組設置:

./configure \
    --disable-bluez \
    --disable-brlapi \
    --disable-curses  \
    --disable-debug-tcg \
    --disable-fdt \
    --disable-guest-agent \
--disable-live-block-migration              --disable-qom-cast-debug            \
--disable-sdl              --disable-sparse              --disable-strip         \
--disable-vnc-jpeg              --disable-xen      --enable-docs \
--enable-kvm \
--enable-lzo               --enable-seccomp              --enable-snappy \
--enable-werror           \
--block-drv-ro-whitelist=vmdk,vhdx,vpc,https   \
--block-drv-rw-whitelist=qcow2,raw,file,host_device,nbd,gluster,blkdebug,luks      \
--disable-xen-pci-passthrough --disable-guest-agent-msi              --enable-attr       \
--enable-coroutine-pool              --enable-debug-info             \
--enable-gnutls \
--enable-numa       \
--enable-system \
--enable-tools         \
--enable-vhost-net \
--enable-vhost-vsock     \
--enable-vnc \
--enable-debug \
--tls-priority=NORMAL \
--with-coroutine=ucontext       \
--extra-cflags="-O2 -g -pipe -Wall  -fexceptions \
-fstack-protector-strong --param=ssp-buffer-size=4 -m64 -mtune=generic -fPIE -DPIE"        \
--extra-ldflags=" -pie -Wl,-z,relro -Wl,-z,now" \
--target-list=x86_64-softmmu

 

仍是不行。。。

 

再試一次:卸載掉qemu-2.0.0的rpm,安裝自編譯的qemu到系統目錄。

[root@D128 qemu-2.12.0-rc3]# yum autoremove qemu qemu-kvm

 

[root@D128 qemu-2.12.0-rc3]# ./configure --enable-curses --enable-vhost-user --target-list=x86_64-softmmu --disable-gtk --enable-docs --enable-numa --enable-kvm --enable-system --enable-modules

 

仍是不行。。。 算了。。。

始終提示CPU STUCK

 

回退一個版本到2.10

[root@D128 qemu]# git branch
  master
* stable-2.10
[root@D128 qemu]# git submodule init
Submodule 'roms/QemuMacDrivers' (git://git.qemu.org/QemuMacDrivers.git) registered for path 'roms/QemuMacDrivers'
[root@D128 qemu]# git submodule update --recursive

再編譯:

仍是不行。。。。

錯誤相似:

[   28.050008] BUG: soft lockup - CPU#2 stuck for 23s! [systemd-udevd:162]
[   56.050010] BUG: soft lockup - CPU#2 stuck for 23s! [systemd-udevd:162]
[   84.050006] BUG: soft lockup - CPU#2 stuck for 23s! [systemd-udevd:162]
[  112.050007] BUG: soft lockup - CPU#2 stuck for 22s! [systemd-udevd:162]
[  140.050006] BUG: soft lockup - CPU#2 stuck for 22s! [systemd-udevd:162]
[  168.050009] BUG: soft lockup - CPU#2 stuck for 22s! [systemd-udevd:162]
[  196.050008] BUG: soft lockup - CPU#2 stuck for 22s! [systemd-udevd:162]
[  224.050006] BUG: soft lockup - CPU#2 stuck for 22s! [systemd-udevd:162]
[  252.050014] BUG: soft lockup - CPU#2 stuck for 22s! [systemd-udevd:162]
[  280.050006] BUG: soft lockup - CPU#2 stuck for 22s! [systemd-udevd:162]

 

退到2.9版本:

2.9也是這樣。好的,放棄了。。。。

 

==========================   我又回來了,@ 2018-04-20  =====================

一直耿耿於懷這個問題。

那麼,首先,soft lookup究竟是什麼問題? 見:

https://www.cnblogs.com/lyhabc/p/6640012.html

簡單的說,就是內核出了問題。而後我用的是標準CentOS7的發行版,因此基本上就是驅動的問題。

那麼對於一個qemu的虛擬機來講,惟一能作的就是改變硬件,以下:

我去掉了全部的網卡,而且去掉disk的virtio驅動。

果真正常運行了!

/root/BUILD_qemu/bin/qemu-system-x86_64 -enable-kvm \
    -m 2G \
    -cpu Nehalem -smp cores=4,threads=2,sockets=2 \
    -numa node,mem=1G,cpus=0-8,nodeid=0 \
    -numa node,mem=1G,cpus=9-15,nodeid=1 \
    -display vnc=0.0.0.0:1 \
    -drive file=disk.img \

查看文檔,改變一下參數,從新把virtio用起來。

在那以前,再編一個qemu-2.12

[root@D128 qemu-2.12.0-rc3]# ./configure --prefix=/root/BUILD_qemu/ --target-list=x86_64-softmmu --disable-gtk --enable-virtfs

 

不認識virtio,換了參數也不行:

#    -device virtio-blk-pci,scsi=off,bus=pci.0,addr=0x7,drive=disk0,bootindex=1 \
#    -drive file=disk.img,if=none,id=disk0 \

 

 kvm+virtio 就會有問題。極可能是VMware的緣由。

 

--------------------------

差一個題外內容:

What is the difference and relationship between 「xx-softmmu」 and 「xx-linux-user」?
To put it simply, xxx-softmmu will compile qemu-system-xxx, which is an emulated machine for xxx architecture (System Emulation). 
When it resets, the starting point will be the reset vector of that architecture. While xxx-linux-user, compiles qemu-xxx,
which allows you to run user application in xxx architecture (User-mode Emulation). Which will seek the user applications'
main function, and start execution from there.
See https://en.wikipedia.org/wiki/QEMU#Operating_modes

 

https://stackoverflow.com/questions/32435138/what-is-the-difference-and-relationship-between-xx-softmmu-and-xx-linux-user?utm_medium=organic&utm_source=google_rich_qa&utm_campaign=google_rich_qa

相關文章
相關標籤/搜索