歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux基礎 >> Linux教程 >> 遷移VMware虛擬機到KVM

遷移VMware虛擬機到KVM

日期:2017/2/27 16:04:17   编辑:Linux教程

簡介

目前 x86 平台上最流行的虛擬化軟件是 VMware 公司的系列產品,而基於開源技術的 KVM 虛擬化軟件也得到了廣泛的應用。本文是虛擬化遷移技術系列文章的第三部分,詳細介紹了如何使用 virt-v2v 開源工具或者手動方法遷移創建在 VMware 軟件上的 Window 及 Linux 虛擬機到基於 KVM 的虛擬機,並且從功能上比較了虛擬機系統遷移前後的變化,最後總結了 VMware 虛擬機到 KVM 遷移的不足和注意事項。

前言

隨著虛擬化技術的不斷發展,虛擬機的應用也越來越廣泛。日常應用中可能出現資源不足,系統管理調整或者系統備份等原因,希望將某一虛擬機從原來物理主機遷移到另一個物理主機上,即 V2V(Virtual-to-Virtual)遷移。虛擬機的遷移需要物理主機上 VMM(Virtual Machine Monitor)的支持。相同類型 VMM 之間,使用相同的 API 接口,通常具有強大的遷移能力。例如本系列第二篇文章介紹的 KVM 虛擬機之間的遷移,它支持三種遷移方式:離線遷移、在線共享存儲遷移和在線塊遷移。而不同的 VMM 之間,由於虛擬化實現技術的不同、開發廠商的不同、API 接口的不同,使虛擬機遷移困難重重。本文分別介紹如何靜態遷移 VMware ESX/ESXi、VMware Workstation 及 VMware Player 上的虛擬機到 KVM 主機。

VMware 虛擬機遷移到 KVM 的方式

虛擬機 V2V(Virtual-to-Virtual)遷移是在虛擬機之間移動操作系統和數據, 照顧主機級別的差異和處理不同的虛擬硬件。V2V 的遷移方法有兩種,靜態遷移和在線遷移。靜態遷移(offline migration)也叫做常規遷移、離線遷移。在遷移之前將虛擬機暫停,同時拷貝虛擬機鏡像和狀態到目的主機。相比較於在線遷移(online migration),其缺點是靜態遷移方式的過程需要顯式的停止虛擬機的運行,而在線遷移的過程僅有非常短暫的停機時間,保證遷移過程中虛擬機服務的持續可用;優點是兼容性強,不需要 VMM 的有統一的 API 接口,可以借助第三方工具輔助遷移。由於目前 VMM 的開發沒有統一的標准,不同的虛擬化廠商,尤其是閉源的商業廠商開發的 VMM 各成一套,靜態遷移是解決不同類型虛擬機之間遷移的有效辦法。本文采用 V2V 靜態遷移的方法實現 VMware 虛擬機到 KVM 的遷移,同時介紹開源遷移工具 virt-v2v 的使用。

VMware 虛擬化產品及虛擬機文件

VMware 產品簡介

VMware 是全球虛擬化解決方案的領導廠商,提供了一套虛擬機解決方案,按產品特點可分為如下四類。  

  1. VMware ESX/ESXi:這個產品不需要安裝任何操作系統,它本身就是一個用來管理硬件資源的特殊的操作系統,所有的虛擬機都安裝在它的上面。ESX Server 帶有遠程 web 管理和客戶端管理功能。
  2. VMware Server、Workstation 和 Fusion:與 ESX 相比,這三個產品都是要安裝在操作系統上的。Server 和 Workstation 運行在 Windows 和 Linux 上,Fusion 運行在蘋果的 Mac OS 上。
  3. VMware VMotion:是 VMware 開發出的一項獨特技術,它將服務器、存儲和網絡設備完全虛擬化,使得正在運行的整個虛擬機能夠在瞬間從一台服務器移到另一台服務器上。
  4. Virtual Center、Importer、Convertor、P2V、Player:這些是為了配合 VMware 虛擬引擎,主要是為了配合 ESX 開發的管理軟件和工具,這些工具中很多是免費的。

本文主要遷移創建在 VMware ESX/ESXi、VMware Workstation 和 VMware Player 上的虛擬機到 KVM 主機上,遷移後的虛擬機可以被開源的 libvirt 軟件管理。

VMware 虛擬機文件介紹

成功遷移虛擬機的一個重要的驗證標准就是文件的正確性和完整性。下圖中列出與 VMware 虛擬機相關的文件,但是遷移 VMware 虛擬機到 KVM 並不需要用到所有的文件。

圖 1. VMware 虛擬機文件 圖 1. VMware 虛擬機文件

VMware 虛擬機的文件主要包括 .nvram 文件,.vmx 文件,vmdk 文件,.vswp 文件,.vmss 文件,.vmsd 文件,.vmsn 文件,.log 文件,.vmxf 文件。與遷移相關的最主要的是 .vmx 文件和 .vmdk 文件。

  1. .vmx 文件:包括虛擬機所有配置信息與硬件設置。不管你對虛擬機的設置做了何種編輯,所有的信息都會以文本形式保存在這個文件裡。如特殊硬件配置(例如 RAM 大小,網絡接口信息,硬盤驅動信息,串行與並行信息),高級能源與資源配置、VMware 工具選項及能源管理選項。遷移虛擬機時,需要更改這個文件的格式到 KVM 支持的 xml 文件,並且重新確認文件信息的有效性。
  2. .vmdk 文件:包含虛擬磁盤的信息。虛擬機的文件系統就建立在 .vmdk 文件上。遷移時需要拷貝這個文件到 KVM 主機,並且轉換成能夠被 libvirt 識別的文件格式。

以下的虛擬機文件有些只在虛擬機處於的某種狀態時出現,遷移過程中不會用到。例如當虛擬機開啟時出現 .vswp 文件,當虛擬機暫停時出現 .vmss 文件。

  1. .nvram 文件:包括虛擬機啟動過程一部分的 Phoenix BIOS。它類似於擁有 BIOS 芯片的物理服務器,能夠設置硬件配置選項。如果刪除的話,在虛擬機啟動時會自動地重新創建。
  2. .vswp file:這些文件的大小等於分配給虛擬機的內存大小,再減去任何內存預留(默認是 0)。這些文件通常創建在虛擬機裡,但是只有當 ESX 主機耗盡所有物理內存時才使用。當虛擬機關閉或暫停時,這些文件將刪除。
  3. .vmss 文件:這個文件用於虛擬機暫停時,保存虛擬機的存儲內容,以便在重新開始時繼續運行。
  4. .vmsd 文件:這個文件與快照一起使用,用於存儲元數據和其他活動在虛擬機裡的每個快照的信息。這個文本文件在創建快照之前的初始大小是 0 字節,並在每次創建或刪除快照時更新信息。
  5. .vmsn 文件:這個文件與快照一起使用,用於存儲虛擬機在進行快照時的狀態。每在虛擬機上創建一個快照就會生成一個 .vmsn 文件,在刪除快照時,文件自動刪除。
  6. .log 文件:這些文件創建來用於存儲虛擬機的日志信息,並常常用於故障檢查。在虛擬機目錄裡,有大量的這樣的文件。當前的日志文件通常命名為 vmware.log。
  7. .vmxf 文件:這是一個附加配置文件,不用於 ESX,用於與 Workstation 兼容的目的。這個文件是文本格式,Workstation 用來聚合虛擬機(VM teaming),將多個虛擬機分配成一組,作為一個單一對象開啟或關閉、暫停或恢復它們。

virt-v2v 遷移 VMware ESX 虛擬機

從 RHEL6(Red Hat Enterprise Linux 6)開始,RHEL 發行版中包含了 Red Hat 公司開發的 virt-v2v 工具。它是由 perl 語言編寫的腳本,可以自動化的將創建在 Xen,KVM 和 VMware ESX 上的虛擬機拷貝到 virt-v2v 的主機,並且自動的更改配置,使之能夠被 libvirt 進行管理。目前,virt-v2v 支持靜態遷移下列虛擬機:RHEL4、RHEL5, RHEL6,Windows XP,Windows Vista, Windows 7, Windows Server 2003 和 Windows Server 2008。

圖 2. virt-v2v 遷移 VMware/Xen/KVM 虛擬機示意圖 圖 2. virt-v2v 遷移 VMware/Xen/KVM 虛擬機示意圖

本節中,將分別介紹如何使用 virt-v2v 工具遷移 Vmware ESXi 上的 RHEL 虛擬機和 Windows 7 虛擬機到 KVM 主機。

遷移前的環境設置

本文的 KVM 主機安裝最新的 RHEL6.1 操作系統(發布於 2011 年 5 月 19 日)。這樣,最基本的支持 KVM 虛擬機的軟件 qemu-kvm、libvirt、virt-manager 和 virt-v2v 工具都在發行版中安裝了。

清單 1. 支持 KVM 虛擬機的軟件包

[root@localhost ~]# rpm -qa qemu-kvm 
 qemu-kvm-0.12.1.2-2.160.el6.x86_64 
 [root@localhost ~]# rpm -qa libvirt 
 libvirt-0.8.7-18.el6.x86_64 
 [root@localhost ~]# rpm -qa virt-manager 
 virt-manager-0.8.6-4.el6.noarch 
 [root@localhost ~]# rpm -qa virt-v2v 
 virt-v2v-0.7.1-3.el6.x86_64

為了使 virt-v2v 工具能夠自動化的遷移 VMware ESX 虛擬機,盡量減少手動干預,還需要在 KVM 主機上做一些設置。

1. 安裝支持 Windows 虛擬機遷移的軟件。

對於 Windows 虛擬機的遷移需要安裝 libguestfs-winsupport 包來支持 NTFS 文件系統和 virtio-win 包來支持 Windows para-virtualized 存儲和網絡設備驅動。

清單 2. 安裝 Windows 虛擬機遷移的支持包

[root@victory4 v2v]# rpm -ivh libguestfs-winsupport-1.0-7.el6.x86_64.rpm  \
 virtio-win-1.2.0-1.el6.noarch.rpm 
 Preparing...                ########################################### [100%] 
   1:virtio-win             ########################################### [ 50%] 
   2:libguestfs-winsupport  ########################################### [100%]

2. 創建 KVM 主機存儲域

virt-v2v 在遷移虛擬機的過程中,需要拷貝被遷移虛擬機到 KVM 主機預先定義的存儲池中。存儲池可以用 libvirt 工具創建。最簡單的方法就是使用 virt-manager 來創建新的存儲池。本文中創建了一個文件目錄類型的存儲池,位置在 KVM 主機系統的 /home/images/migration 目錄。

圖 3. 使用 virt-manager 創建本地存儲域 圖 3. 使用 virt-manager 創建本地存儲域

3. 創建 KVM 主機網絡接口

虛擬機在遷移之後將連接 KVM 主機網絡, 因此主機必須有一個與之相匹配的網絡接口,比如說網橋。Linux 系統上有很多工具可以創建網橋,其中 RHEL6.1 發行版上的 virt-manager 已經支持創建和管理網橋。本文創建了網橋 br0,並且綁定在 eth0 的接口上,具體配置如下圖。

圖 4. 使用 virt-manager 創建網橋 圖 4. 使用 virt-manager 創建網橋

4. 創建配置文件 virt-v2v.conf

在 virt-v2v.conf 文件中設置 virt-v2v 遷移的規則,包括網絡接口遷移後的映射,遷移的方式,存儲的位置,輸出的格式等等。這些規則也能以命令行參數的方式輸入,如 - - network,-o,-os,-of 等。

virt-v2v 遷移 VMware 虛擬機的步驟

在 KVM 主機上完成上節的准備工作後,可以正式開始遷移 VMware ESX 上的虛擬機了。下面是遷移的具體步驟:

1. 如果虛擬機上安裝了 VMware Tools,必須先卸載它。因為 KVM 的虛擬機不支持 VMware Tools 裡面的虛擬驅動。

2. 在 VMware ESX 上停止等待遷移的虛擬機,因為 virt-v2v 只支持靜態遷移。

3. 為自動登錄 VMware ESX 服務器創建 .netrc 文件。VMware ESX 服務器的連接需要授權,virt-v2v 支持密碼方式的授權連接,可以從 $HOME/.netrc 文件中讀取密碼並自動登錄。如果主機系統沒有這個文件,就手動創建它。並且 .netrc 文件需要 0600 權限,使 virt-v2v 工具可以正確讀取它。

清單 3. .netrc 文件的格式

machine esx.example.com login root password xxxxxx

4. 使用 virt-v2v 命令進行遷移。VMware ESX 服務器采用 HTTPS 連接方式,連接時需要配置 SSL 證書。本文通過添加'?no_verify=1'; 到 VMware 服務器的 URI 連接中,來關閉證書檢查。

清單 4. virt-v2v 遷移命令及參數

virt-v2v -ic esx://esx.example.com/?no_verify=1 -os pool --bridge brname vm-name 
    
 esx.example.com – 是 ESX 服務器主機名或 IP Address 
 pool – 本地主機存儲池,用來保存鏡像
 brname – 本地主機網橋名字,用來連接遷移後的虛擬機網絡
 vm-name – 虛擬機的名字

5. 遷移成功後,虛擬機出現在 virt-manager 管理的虛擬機列表中。通過 virt-manager 工具啟動虛擬機。

6. 檢查遷移後的虛擬機的設備驅動。如果需要,重新安裝虛擬設備驅動。

7. 驗證遷移後的虛擬機的配置和系統是否和遷移之前一致。

virt-v2v 遷移實例:Linux 虛擬機 RHEL5.5

本例將遷移創建在 VMWare ESXi 服務器上的 RHEL5.5 虛擬機到 KVM 主機上,並使遷移後的虛擬機被 libvirt 管理。本例的環境中,VMware ESXi 服務器和 KVM 主機通過網絡連接,虛

擬機鏡像被各自的存儲管理。

圖 5. virt-v2v 遷移 RHEL5 虛擬機的環境 圖 5. virt-v2v 遷移 RHEL5 虛擬機的環境

下面就開始正式的遷移 :

1. 在 VMware ESXi 上檢測 RHEL5.5 虛擬機,如果安裝了 VMware Tools,先卸載它。

2. 在 VMware ESXi 上關閉 RHEL5.5 虛擬機。

3. 在 KVM 主機上創建或修改 $HOME/.netrc 文件,添加 VMware ESXi 服務器的用戶名和密碼。

清單 5. 修改 .netrc 文件

[root@localhost home]# cat ~/.netrc 
 machine 9.123.99.913 login root password xxxxxx 
[root@localhost home]# chmod 0600 ~/.netrc

4. 開始遷移虛擬機。KVM 的存儲是遷移前准備好的存儲域 migration,文件格式采用 libvirt 支持的 qcow2,網絡連接方式與 VMware 虛擬機相同,采用網橋。

清單 6. 遷移 RHEL5.5 虛擬機

[root@localhost ~]# virt-v2v -ic esx://9.123.99.193/?no_verify=1 \
 -os migration -of qcow2 --bridge br0 RHEL5.5 
 Using CPU model "cpu64-rhel6"
 RHEL5.5_RHEL5.5: 100% [=============================================]D 0h22m52s 
 Using CPU model "cpu64-rhel6"
 virt-v2v: RHEL5.5 configured with virtio drivers 

參數說明
 -os migration:  遷移虛擬機的鏡像文件到主機上的存儲池
 -of qcow2:     轉換遷移後虛擬機的文件格式
 --bridge br0:  設置遷移後虛擬機的網絡映射到網橋 br0 
 RHEL5.5:        Vmware ESXi 上虛擬機的名字,遷移後保持名字一致

5. 在 KVM 主機上啟動 virt-manager 軟件,就會發現遷移後的虛擬機已經被 libvirt 管理了。

圖 6. virt-manager 管理遷移後的 RHEL5.5 虛擬機 圖 6. virt-manager 管理遷移後的 RHEL5.5 虛擬機

6. 深入比較遷移前在 VMware ESXi 上的虛擬機和遷移後在 KVM 上的虛擬機。


RHEL5.5 VMware ESXi KVM/Libvirt 結論 CPUs Intel Xeon 5160 x2 QEMU vCPU
(cpu64-rhel6) 數量一致,類型和轉化為虛擬 CPU,主頻和支持的 flags 有變化 Memory 1384M 1384M 數量一致 Hard Disk 18GB,
LSI Logic SCSI
VMDK 18GB
virtio SCSI
qcow2 大小一致,總線接口和文件系統轉換為適合 libvirt 的類型 CDROM IDE IDE 類型一致 Network Adaptor MAC 00:0c:29:a9:7b:83
Type: e1000
vSwitch0
DHCP MAC 00:0c:29:a9:7b:83
Type: virtio
bridge br0
DHCP Mac 相同,網卡類型和連接方式轉換為適合 libvirt 的類型 Video Card Vmware SVGA
4M Video RAM Model: Cirrus
9M RAM 轉換為 libvirt 支持的類型 系統用戶 root/admin001 root/admin001 一致 磁盤分區 VolGroup00
/dev/sda VolGroup00
/dev/vda 邏輯卷一致,物理盤符有變化。 表 1. RHEL5.5 虛擬機遷移前後在 VMware ESXi 和 KVM 上的比較

從表中的比較看出,RHEL5.5 從 VMware ESXi 服務器遷移到 KVM 主機上後,由於 Hypervisor 的不同,硬件發生了很大的變化。但是 virt-v2v 工具很好的解決的這個問題,使用 virtio 虛擬設備驅動使 RHEL5.5 系統遷移後能夠流暢的運行。除了 RHEL5,virt-v2v 還支持 RHEL4 及 RHEL6 版本的遷移。

virt-v2v 遷移實例:Windows 虛擬機 WinXP,Win7

本例中將介紹如何使用 virt-v2v 工具遷移創建在 VMware ESXi 上的 Windows 虛擬機,包括 Windows XP SP3 32bit 中文版和 Windows 7 Professional 32bit 中文版。本節的環境中,KVM 主機上安裝了 virt-v2v 及相應的支持包 libguestfs-winsupport 和 virtio-win。VMware ESXi 服務器和 KVM 主機通過網絡連接,虛擬機鏡像被各自的存儲管理。

圖 7. virt-v2v 遷移 Windows 虛擬機的環境 圖 7. virt-v2v 遷移 Windows 虛擬機的環境

下面是正式的遷移步驟:

1. 在 VMware ESXi 上檢測 WinXP 和 Win7 虛擬機,如果安裝了 VMware Tools,先卸載它。

2. 在 VMware ESXi 上關閉 WinXP 和 Win7 虛擬機。

3. 在 KVM 主機上創建或修改 $HOME/.netrc 文件,添加 VMware ESXi 服務器的用戶名和密碼。

4. 開始遷移虛擬機。KVM 的存儲是遷移前准備好的存儲域 migration,文件格式采用 libvirt 支持的 qcow2,網絡連接方式與 VMware 虛擬機相同,采用網橋。

清單 7. 遷移 WinXP 虛擬機

[root@localhost ~]# virt-v2v -ic esx://9.123.99.193/?no_verify=1 \
 -os migration -of qcow2 --bridge br0 WinXP 
 Using CPU model "cpu64-rhel6"
 WinXP_WinXP: 100% [=========================================================]D 0h11m13s 
 Using CPU model "cpu64-rhel6"
 virt-v2v: WARNING: There is no virtio net driver available in the directory 
 specified for this version of Windows. The guest will be configured with 
 a rtl8139 network adapter, but no driver will be installed for it.
  If the rtl8139 driver is not already installed in the guest, you must install 
  it manually after conversion. 
 virt-v2v: WinXP configured with virtio storage only. 

清單 8. 遷移 Win7 虛擬機

[root@localhost ~]# virt-v2v -ic esx://9.123.99.193/?no_verify=1 \
 -os migration -of qcow2 --bridge br0 Win7 
 Using CPU model "cpu64-rhel6"
 Win7_Win7: 100% [====================================
 ===================================
 =======================================]D 0h35m41s 
 Using CPU model "cpu64-rhel6"
 virt-v2v: Win7 configured with virtio drivers 
 [root@localhost ~]# 

5. 遷移完成後,在 KVM 主機上啟動 virt-manager 軟件,會發現遷移後的 Windows 虛擬機已經被 libvirt 管理了。

6. 在 KVM 上啟動虛擬機後,由於更新了一些虛擬硬件設備,可能需要重新安裝驅動程序和重啟系統。

7. 深入比較遷移前在 VMware ESXi 上的虛擬機和遷移後在 KVM 上的虛擬機,


WinXP VMware ESXi KVM/Libvirt 結論 CPUs Intel Xeon 5160 Intel Pentium II 處理器 數量一致,類型和轉化為虛擬 CPU,主頻和支持的 flags 有變化 Memory 1256M 1256M 數量一致 Hard Disk 8GB,
Vmware Virtual IDE
VMDK 8GB
Virtio SCSI
qcow2 大小一致,總線接口和文件系統轉換為適合 libvirt 的類型 CDROM VMware IDE IDE 類型一致 Network Adaptor MAC 00:0c:29:83:86:d7
Type: PCNET
vSwitch0
DHCP MAC 00:0c:29:83:86:d7
Type: rtl8139
bridge br0
DHCP Mac 相同,網卡類型和連接方式轉換為適合 libvirt 的類型 Video Card Vmware SVGA
4M Video RAM Model: Cirrus
9M RAM 轉換為 libvirt 支持的類型 系統 Administrator/admin001 Administrator/admin001 一致 磁盤分區 C:\
D:\ C:\
D:\ 一致 表 2. WinXP 虛擬機遷移前後在 VMware ESXi 和 KVM 上的比較


Win7 VMware ESXi KVM/Libvirt 結論 CPUs Intel Xeon 5160 x 2 X86 family 6 x 2 數量一致,類型和轉化為虛擬 CPU,主頻和支持的 flags 有變化 Memory 1024M 1024M 數量一致 Hard Disk 24GB,
LSI Logic SCSI
VMDK 24GB
Virtio SCSI
qcow2 大小一致,總線接口和文件系統轉換為適合 libvirt 的類型 CDROM VMware IDE IDE 類型一致 Network Adaptor MAC 00:0c:29:64:de:6a
Type: e1000
vSwitch0
DHCP MAC 00:0c:29:64:de:6a
Type: virtio
bridge br0
DHCP Mac 相同,網卡類型和連接方式轉換為適合 libvirt 的類型 Video Card Vmware SVGA
8M Video RAM Model: Cirrus
9M RAM 轉換為 libvirt 支持的類型 系統 Administrator/admin001 Administrator/admin001 一致 磁盤分區 C:\
D:\ C:\
D:\ 一致 表 3. Win7 虛擬機遷移前後在 VMware ESXi 和 KVM 上的比較

從表中的比較看出,Windows 虛擬機從 VMware ESXi 服務器遷移到 KVM 主機上後,由於 Hypervisor 的不同,硬件發生了很大的變化。Virt-v2v 工具盡量在 KVM 虛擬機上使用 Virtio 虛擬設備加速系統的 IO 設備。WinXP 虛擬機的遷移後,使用了磁盤的 virtio 驅動而網絡設備使用默認的 rtl8139。 Win7 虛擬機的遷移後磁盤和網絡全部使用 virtio 的驅動。Virt-v2v 還支 Windows Vista,Win2003,Win2008 虛擬機從 VMware ESX/ESXi 上的遷移,步驟和 WinXP,Win7 虛擬機類似。

virt-v2v 遷移小結

virt-v2v 工具自動化的解決了 VMware ESX/ESXi 服務器上的 RHEL 虛擬機和 Windows 虛擬機遷移到 KVM 主機的問題。而且在遷移的過程中盡量的使用 virtio 驅動提高 IO 設備的性能。但是,virt-2v2 工具也有一些局限性。比如只支持虛擬機關機情況下的靜態遷移;只支持 RHEL 虛擬機和 Windows 虛擬機的遷移;不支持 VMware 虛擬機快照的遷移。對於創建在 VMware Workstation/Player 上的虛擬機,目前 virt-v2v 還不支持自動遷移。但是我們可以用手動遷移的方法完成到 KVM 主機的遷移。請看下節:手動遷移 VMware Workstation/Player 上的虛擬機到 KVM 。

手動遷移 VMware Workstation/Player 上的虛擬機到 KVM

從物理機的文件系統看,VMware 虛擬機是由一組文件組成。這些文件可能集中存儲在存儲服務器上,如 VMware ESX/ESXi,也可能存儲在本地,如 VMware Workstation/Player。關閉虛擬機的情況下,這些文件內容不會改變。所以我們可以用手動遷移的方法,拷貝這些文件到 KVM 主機並且轉換這些文件的格式或內容,使 libvirt 能夠管理和識別。這樣就完成了 VMware 虛擬機的手動遷移。

手動遷移的准備工作

在 VMware 虛擬機眾多的文件中,最重要的是虛擬機鏡像文件 .vmdk 和系統配置文件 .xml。所以手動遷移就是要分別處理這兩種文件。

  • 合並分散的 vmdk 鏡像文件。在 VMware Workstation 上創建虛擬機的時候,可以選擇存儲虛擬磁盤為一個文件或多個文件。但是 libvirt 不能管理多個文件組成的磁盤鏡像,所以需要在遷移前合並這些文件為一個單獨的文件。VMware Workstation 自帶了離線的磁盤管理工具 vmware-vdiskmanager.exe 來合並 vmdk 文件。
圖 8. 多個文件存儲的 VMware 虛擬機 圖 8. 多個文件存儲的 VMware 虛擬機
  1. qemu-img 轉換 vmdk 的文件格式。KVM 主機上安裝 qemu-img 包,可以察看並轉換 vmdk 文件到 raw/qcow2 文件格式。
  2. 創建 xml 文件。VMware 的系統配置文件是 vmx,必須轉換成 libvirt 能夠識別的 xml 格式。一種方法是根據 VMware 虛擬機的硬件信息,手動創建一個新的 xml 文件;另一種方法是利用工具輔助轉換 vmx 文件。比如 virt-goodies/vmware2libvirt 工具,可以從下面 link 下載安裝 virt-goodies:https://launchpad.net/ubuntu/+source/virt-goodies/0.4

下面我們以 VMware Workstations 上的 SUSE Linux Enterprise Server 11 SP1 虛擬機和 VMware Player 上的 Windows 2008 R2 虛擬機為例,詳細介紹遷移到 KVM 主機的步驟。

手動遷移 VMware Workstation 上的 SLES11SP1 虛擬機

VMware Workstation 軟件安裝在一個 Windows XP 系統上,然後創建 SLES11SP1 虛擬機。虛擬機的文件都存儲在本地。KVM 主機通過網絡連接到 Window XP 系統。

圖 9. 手動遷移 SLES11SP1 虛擬機的環境 圖 9. 手動遷移 SLES11SP1 虛擬機的環境

遷移的過程如下:

1. 登錄宿主機 Windows XP 系統,在 VMware Workstation 上檢查 SLES11SP1 虛擬機,如果安裝了 VMware Tools,以 root 用戶運行 vmware-uninstall-tools.pl 卸載它。

2. 關閉 SLES11SP1 虛擬機。

3. 檢查虛擬機的鏡像文件。本例中,虛擬機的鏡像存儲在多個 vmdk 文件中,所以需要在遷移前合並他們。

圖 10. 用 vmware-vdiskmanager.exe 合並多個 vmdk 文件 圖 10. 用 vmware-vdiskmanager.exe 合並多個 vmdk 文件

4. 拷貝合並後的 vmdk 文件到 KVM 主機上。本例中,拷貝文件 SLES11SP1-single.vmdk 到 KVM 主機的 /home/images/migration 目錄下。並且使用 qemu-img 工具將 vmdk 文件轉換成 qcow2 格式的文件。可以看出,轉換後鏡像文件 SLES11SP1-single.img 的實際大小 3.9G 和最大范圍 20G 沒有改變,僅僅是文件系統類型變化了

清單 9. 轉換 vmdk 文件到 qcow2 格式

[root@localhost migration]# qemu-img info SLES11SP1-single.vmdk 
 image: SLES11SP1-single.vmdk 
 file format: vmdk 
 virtual size: 20G (21474836480 bytes) 
 disk size: 3.9G 

 [root@localhost migration]# qemu-img convert -f vmdk \
 -O qcow2 SLES11SP1-single.vmdk SLES11SP1-single.img 

 [root@localhost migration]# qemu-img info SLES11SP1-single.img 
 image: SLES11SP1-single.img 
 file format: qcow2 
 virtual size: 20G (21474836480 bytes) 
 disk size: 3.9G 
 cluster_size: 65536 


5. 轉換 vmx 文件。本例介紹第一種方法,即手動創建 vmx 文件。首先要找出 SLES11SP1 虛擬機全部虛擬設備信息,這些信息可以從 VMware Workstation 的管理界面和虛擬機系統的系統信息獲得;然後在 KVM 主機上的 virt-manager 中,以第 4 步轉換完成的鏡像文件 SLES11SP1-single.img 為基礎創建一個虛擬機;最後添加與 VMware 相同或類似的硬件,並且盡量保證數量、類型和配置的一致,包括 CPU 和 MEM 數量、系統構架、網絡類型、MAC 地址等。

圖 11. VMware Workstation 上查看虛擬機的硬件信息 圖 11. VMware Workstation 上查看虛擬機的硬件信息
圖 12. 手動配置 KVM 虛擬機 圖 12. 手動配置 KVM 虛擬機

6. 設置完成後,自動創建 KVM 虛擬機的配置文件 /etc/libvirt/qemu/SLES11SP1.xml,並且 virt-manager 可以管理這個 SLES 虛擬機了。在 libvirt 上啟動虛擬機,手動配置虛擬機系統以適應新的硬件。

7. 深入比較遷移前在 VMware Workstation 上的虛擬機和遷移後在 KVM 上的虛擬機。



SLES11SP1 VMware Workstation KVM/Libvirt 結論 CPUs Intel Core2 x 2 QEMU vCPU x 2 數量一致,類型和轉化為虛擬 CPU,主頻和支持的 flags 有變化 Memory 768M 768M 數量一致 Hard Disk 20GB
LSI Logic SCSI
VMDK 20GB
IDE
qcow2 大小一致,總線接口和文件系統轉換為適合 libvirt 的類型 CDROM IDE IDE 類型一致 Floppy 類型一致 USB Controller USB 2.0 Physical USB device libvirt 對 USB 的支持較弱 Network Adaptor MAC 00:0c:29:68:16:33
Type: PCNet
NAT
Virtual DHCP MAC 00:0c:29:a9:7b:83
Type: Virtio
NAT
Virtual DHCP Mac 相同,網卡類型和連接方式轉換為適合 libvirt 的類型 Video Card Vmware SVGA Model: Cirrus
9M RAM 轉換為 libvirt 支持的類型 Audio device ES1371 ES1370 轉換為 libvirt 支持的類型 系統用戶 root/admin001 root/admin001 一致 磁盤分區 /dev/sda1
/dev/sda2 /dev/sda1
/dev/sda2 物理盤符及系統分區一致 表 4. SLES11SP1 虛擬機遷移前後在 VMware Workstation 和 KVM 上的比較

和使用 virt-v2v 自動化遷移工具相比,手動遷移增加了很多工作和不確定性。在本系列文章第一篇列舉了”Linux 系統在虛擬機遷移中的技術難點”,此處正好驗證了手動遷移中需要注意的問題。比如在本例中,有以下兩個問題:

  1. 如何選擇磁盤總線類型。virt-v2v 工具自動選擇 virtio 磁盤驅動來提高 KVM 虛擬機的性能,但是在本例中,SLES 虛擬機不能直接使用 virtio 磁盤驅動。因為 SLES 系統的磁盤分區名在 /etc/fstab 被硬編碼為 /dev/sda,而 virtio 磁盤分區名為 /dev/vda,直接使用 virtio 磁盤驅動會導致系統找不到分區而無法啟動的錯誤。所以本例為 KVM 虛擬機選擇了性能較差的 IDE 磁盤類型。
  2. Xwindow 需要重新配置。SLES 虛擬機不能自動處理顯示設備的變化,所以需要手動運行 SaX2 重新配置 Xwindow 並重新啟動 gdm。

實際上,手動把 SLES 虛擬機裡面關於磁盤分區的硬編碼全部改成 UUID 後,就可以使用高性能的 virtio 磁盤驅動。具體操作方法將在本系列文章的第五部分介紹。

手動遷移 VMware Player 上的 Win2008R2 虛擬機

VMware Player 軟件安裝在 Linux 系統上,然後創建了 Windows 2008 R2 虛擬機。虛擬機的文件都存儲在本地。KVM 主機通過網絡連接到 VMware Player 的主機系統。

圖 13. 手動遷移 Win2008R2 虛擬機的環境設置 圖 13. 手動遷移 Win2008R2 虛擬機的環境設置

遷移的過程如下:

1. 登錄宿主機 Linux 系統,在 VMware Player 上檢查 Win2008R2 虛擬機,如果安裝了 VMware Tools,必須先卸載它。

2. 關閉 Win2008R2 虛擬機,因為手動遷移必須保持虛擬機文件的一致性。

3. 檢查虛擬機的鏡像文件。如果虛擬機的鏡像存儲在多個 vmdk 文件中,需要在遷移前合並。本例的 VMware 虛擬機存儲在單獨的 vmdk 文件中,所以略過此步。

4. 拷貝 vmdk 文件到 KVM 主機上。本例中,拷貝 Win2008R2.vmdk 文件到 KVM 主機的 /home/images/migration 目錄下。並且使用 qemu-img 工具將 vmdk 文件轉換成 qcow2 格式的文件。可以看出,轉換後鏡像文件 Win2008R2.img 的實際大小 6.4G 和最大范圍 20G 沒有改變,僅僅是文件系統類型變化了。

清單 10. 轉換 vmdk 文件到 qcow2 格式

[root@localhost migration]# qemu-img info Win2008R2.vmdk 
 image: Win2008R2.vmdk 
 file format: vmdk 
 virtual size: 20G (21474836480 bytes) 
 disk size: 6.4G 

 [root@localhost migration]# qemu-img convert -f vmdk \
 -O qcow2 Win2008R2.vmdk Win2008R2.img 

 [root@localhost migration]# qemu-img info Win2008R2.img 
 image: Win2008R2.img 
 file format: qcow2 
 virtual size: 20G (21474836480 bytes) 
 disk size: 6.4G 
 cluster_size: 65536 

5. 轉換 vmx 文件。virt-goodies/vmware2libvirt 腳本是用來做 vmx 到 xml 轉換的簡單工具。但是由於它很長時間沒有升級,而且不同的 Linux 發行版對 KVM/libvirt 安裝方式不同,vmware2libvirt 工具轉換後的 xml 文件需要手動更改或添加某些配置。

  1. 注意不同 Linux 發行版 qemu-kvm 的路徑不同,RHEL6.1 下是 /usr/libexec/qemu-kvm。
  2. 把虛擬機的鏡像文件路徑及名字改成 /home/images/migration/Win2008R2.img。
  3. vmware2libvirt 只轉換第一塊網卡,如果有多塊網卡需要手動添加。
  4. vmware2libvirt 不轉換 CDROM、Floppy、USB 和顯示設備,需要手動為 KVM 虛擬機添加。
  5. 磁盤和網卡采用默認的驅動程序,因為 Windows 系統沒有預裝 virtio 驅動。

清單 11. vmware2libvirt 轉換 vmx 文件

[root@localhost migration]# /home/vmware2libvirt \
 -f Win2008R2.vmx > /etc/libvirt/qemu/Win2008R2.xml 
添加 Win2008R2 到 virt-manager 
 [root@localhost migration]# virsh -c qemu:///system \
 define /etc/libvirt/qemu/Win2008R2.xml 
 Domain Win2008R2 defined from /etc/libvirt/qemu/Win2008R2.xml


6. 在 virt-manager 中啟動 Win2008R2 虛擬機,手動添加缺少的硬件。

圖 14. KVM 上 Win2008R2 虛擬機的配置 圖 14. KVM 上 Win2008R2 虛擬機的配置

7. 啟動虛擬機,檢查系統狀態。


Win2008R2 VMware Player KVM/Libvirt 結論 CPUs Intel Core Duo 2.66G x 2 QEMU vCPU 2.66G x 2 數量一致,類型和轉化為虛擬 CPU,主頻和支持的 flags 有變化 Memory 1024M 1024M 數量一致 Hard Disk 20GB,
LSI Logic SCSI
VMDK 20GB
IDE
qcow2 大小一致,總線接口和文件系統轉換為適合 libvirt 的類型 CDROM VMware IDE IDE 類型一致 Network Adaptor MAC 00:0c:29:aa:9b:a4
Type: e1000
NAT MAC 00:0c:29:aa:9b:a4
Type: e1000
NAT Mac 地址、網卡類型和連接方式相同 Video Card Vmware SVGA Model: Cirrus
9M RAM 轉換為 libvirt 支持的類型 系統 Administrator/qwe123OP Administrator/qwe123OP 一致 磁盤分區 C:\
D:\ C:\
D:\ 一致 表 5. Win2008R2 虛擬機遷移前後在 VMware Player 和 KVM 上的比較

由上表可以看出,Win2008R2 虛擬機遷移到 KVM 後,雖然硬件有變化,但是不影響操作系統及軟件的運行。這此遷移過程中沒有使用任何 virtio 的驅動程序,因為 Windows 系統本身沒有 virtio 的驅動。如果想使用 virtio 來提高 KVM 虛擬機的性能,參見下節如何用 virtio 驅動光盤或軟盤手動安裝。

在 Windows 虛擬機上手動安裝 virtio 驅動

實際上,virtio 驅動光盤鏡像文件和軟盤鏡像文件包含在清單 2 列出的 virtio-win 包中。只需要在虛擬機的虛擬光驅或軟驅中裝載這些鏡像文件,就可以升級磁盤和網卡驅動為 virtio 驅動了。

清單 12. virtio 光盤鏡像和軟盤鏡像文件

[root@localhost migration]# rpm -ql virtio-win 
 ....... 
 /usr/share/virtio-win/virtio-win-1.2.0.iso 
 /usr/share/virtio-win/virtio-win-1.2.0.vfd 
 /usr/share/virtio-win/virtio-win.iso 
 /usr/share/virtio-win/virtio-win.vfd 

下面以上一個小節中,遷移到 KVM 的 Win2008R2 虛擬機為例,介紹如何在 Windows 虛擬機上安裝 virtio 驅動。

1. 在虛擬光驅中加載 virtio 鏡像。

圖 15. 加載 virtio 光盤鏡像 圖 15. 加載 virtio 光盤鏡像

2. 更改網卡的類型為 virtio,這樣系統啟動後可以從 virtio 光盤升級網卡驅動程序。

3. 此時不能更改磁盤的驅動類型。因為此時 virtio 驅動還沒有安裝,直接更改磁盤類型會導致系統無法啟動的錯誤。替代方法是臨時添加一塊新的磁盤,大小隨意,類型為 virtio。

圖 16. 添加臨時 virtio 磁盤 圖 16. 添加臨時 virtio 磁盤

4. 啟動虛擬機並登陸系統,查看硬件設備管理器。發現缺少了網卡和磁盤控制器的驅動。用 virtio 光盤中的驅動安裝他們。

圖 17. 安裝 virtio 驅動 圖 17. 安裝 virtio 驅動

5. 安裝完成後,關閉虛擬機。刪除臨時磁盤並把主磁盤的類型改為 virtio,然後啟動虛擬機。這時你會發現 Win2008R2 虛擬機已經用上 virtio 的磁盤和網卡設備了。

目前 virtio 光盤鏡像包含 WinXP、Win7、Win2003 和 Win2008 四個平台的驅動程序,都可以用上面這種方法手動安裝。

小結

以上章節詳細介紹了幾種遷移 VMware 虛擬機到 KVM 的方法,下面總結一下各種遷移方法的的優缺點。

  1. virt-v2v 工具是專門針對 VMware ESX/ESXi 的自動化遷移工具,而且支持的虛擬機系統僅限於 RHEL 和 Windows 虛擬機。Virt-v2v 在遷移後的 KVM 虛擬機中優先使用 virtio 虛擬驅動來提高系統 IO 的性能。如果不支持,才選用性能稍低,但更穩定可靠的虛擬硬件。而且這個過程全部自動化完成。
  2. 手動遷移可以涵蓋所有的 VMware 軟件和所有的虛擬機系統。從而遷移中面臨的問題也是多樣化的,需要不同程度的手動干預。某些特定的環境下,可以使用一些工具來輔助手動遷移,比如 virt-goodies/vmware2libvirt。另外 libvirt 也在開發支持 VMware Workstation/Player 遷移的新功能。

不論是 virt-v2v 自動化工具還是手動遷移,由於商業軟件 VMware 開放的編程接口的限制,VMware 虛擬機到 KVM 的遷移有一些軟肋:

  1. 一些 VMware 虛擬機的特性沒有辦法遷移到 KVM 虛擬機上。比如 VMware 虛擬機廣泛使用的快照功能。
  2. 只能實現關閉虛擬機情況下的靜態遷移,無法做到虛擬機不關機情況下的在線遷移。
  3. 一些特殊的 VMware 設備不能遷移到 KVM 虛擬機,於是采用了類似功能的硬件設備替代。比如 VMware Tools 中的虛擬驅動、VMware SVGA、VMware USB Controller 等。
總的來說,VMware 虛擬機到 KVM 的遷移不夠成熟和自動化,遷移的過程需要手動干預。這要求遷移的操作人員具有相關的知識和經驗。開源工具 virt-v2v 的出現簡化了 VMware ESX/ESXi 上部分虛擬機的遷移,而且計劃將來支持 VMware Workstation/Player 上虛擬機的自動遷移。反言之,自動化的遷移工具不就是用腳本語言把手動遷移的步驟和條件程序化麼?掌握了手動遷移,才能了解虛擬機遷移更多的奧秘。
Copyright © Linux教程網 All Rights Reserved