五、Kvm虛擬機遷移


 

一、遷移簡介

遷移:

      系統的遷移是指把源主機上的操作系統和應用程序移動到目的主機,並且能夠在目的主機上正常運行。在沒有虛擬機的時代,物理機之間的遷移依靠的是系統備份和恢復技術。在源主機上實時備份操作系統和應用程序的狀態,然后把存儲介質連接到目標主機上,最后在目標主機上恢復系統。隨着虛擬機技術的發展,系統的遷移更加靈活和多樣化。

 

最終我們遷移的目的就是:

    簡化系統維護管理

    高系統負載均衡

    增強系統錯誤容忍度

    優化系統電源管理

 

二、熱遷移 ---Live Migration

KVM 虛擬機的熱遷移 ---Live Migration:

      服務器虛擬化技術是當前的熱點,而虛擬機的“熱遷移( Live Migration )”技術則是虛擬化技術當中的熱點。

 

熱遷移(又叫動態遷移、實時遷移),即虛擬機保存( save ) / 恢復 (restore) :將整個虛擬機的運行狀態完整保存下來,同時可以快速的恢復到原有硬件平台甚至是不同硬件平台上。恢復以后,虛擬機仍舊平滑運行,用戶不會察覺到任何差異。

 

遷移的種類:

P2P :物理機之間的遷移

V2P :虛擬機遷到物理機

P2V :物理機遷到虛擬機

V2V :虛擬機遷到虛擬機

 

三、熱遷移的應用

1. 虛擬機的熱遷移技術最初是被用於雙機容錯或者負載均衡:當宿主機出現軟硬件故障導致服務異常時,虛擬機可漂移到另外主機上,或者在集群中依據工作負載量的大小,選擇更換宿主機與否來保證自身良好的服務提供性。

 

2. 系統硬件維護:當前很多操作系統都能夠穩定支持 7×24 運行,但是硬件卻需要定期的進行維護。如果使用虛擬機的動態遷移技術,將虛擬機從需要維護的物理機器遷移到另外一主器,等維護完成后,在將其遷回到原來的物理機器。所有的系統服務和應用程序在遷移 & 恢復后仍舊正常運行,用戶不會察覺到由於硬件維護造成的中斷。最終實現了我們服務不受硬件維護干擾的 7*24 小時的工作願望。

 

3. 數據庫備份:對於一些大型、關鍵的數據庫應用,備份是一項重要但復雜的工作。虛擬機的保存/ 恢復可以將數據庫運行在虛擬機中,如需備份就保存虛擬機,這樣數據庫中的所有數據、狀態都做了備份。如果數據庫崩潰了,就可以通過恢復虛擬機來恢復整個數據庫。

 

4. 環境重現:進行性能測試或程序調試時,都需要重現當時復雜龐大並且與實時完全一致的網絡環境 , 不僅僅是重啟、配置軟件,而且常常需要一定的運行時間。我們可以將各服務安裝到獨立的各個虛擬機,然后利用各個獨立虛擬機部署我們所需的工作環境,可以大大縮短環境重現時間。

 

5. 計算機共享: 在一些公共場合用戶需要共享計算機,但是由於不同的系統配置和軟件需要花費大量的時間來配置和恢復。這時使用虛擬機的保存 /恢復可以很好地解決這個問題。或者也可以,在物理機上運行多個邏輯虛擬機幫助我們分配給每一個需要者一個獨立,安全,穩定的環境。當因為宿主機出現問題影響虛擬機使用時,我們可以讓該虛擬機漂移到其他宿主機以此來保持正常工作。

 

四、熱遷移的優勢

1. 首先是可伸縮性比較強, IT 管理者可以在合理時間段讓運行某些關鍵業務的服務器適當減少工作量,以便進行更新操作系統,給應用程序打補丁等。而到了服務高峰期,又可以彈性地進行大負載量的運算。虛擬機遷移過程完全透明,幾乎不影響使用。

 

2. 其次,現在的數據中心都追求環保節能, 工作量負載大的應用程序必然會令服務器能耗增加,有了虛擬機熱遷移技術,當一台物理服務器負載過大時,系統管理員可以將其上面的虛擬機遷移到其他服務器,可有效減低數據中心服務器的總體能耗,再通過冷卻系統將數據中心的溫度保持在正常水平。

 

五、熱遷移的局限

進行虛擬機的熱遷移也有不少的限制。例如,

      VMotion 在進行遷移之前,管理軟件會檢測目標服務器的 X86 架構是否與原服務器兼容。包括存儲設備以及處理器,虛擬機必須放到共享的存儲里, CPU 的類型也要一樣,不僅不能一個是英特爾,一個是 AMD ,甚至相同廠商不同產品線的CPU 也不行,比如英特爾至強和奔騰

 

 

 

六、衡量虛擬機遷移的效率

1. 整體遷移時間:從源主機中遷移操作開始到目的主機上客戶機服務處於不可用狀態的時間,此時源主機上客戶機已經暫停服務,目的主機上的客戶機還未恢復服務。

 

2. 服務器停機時間:在遷移過程中,源主機和目的主機上的客戶機都處於不可用狀態的時間,此時源主機上客戶機已暫停,目的目的主機上客戶還未恢

復服務。

 

3. 對服務的性能影響:不僅包括遷移后的客戶機中應用程序的性能與遷移前相對比是否有所降低,還包括遷移后對目的主機上的其他服務的性能影響。

 

Kvm 動態遷移,也有如下幾個建議和注意事項:

1. 源宿主機和目的宿主機直接盡量用網絡共享的存儲系統來保存客戶機磁盤鏡像。例如 NFS , ISCSI , Glusterfs 等。

2. 為了提高動態遷移的成功率,盡量在同類型 cpu的主機上面進行動態遷移,盡管 kvm 動態遷移也支持從 Intel 平台遷移到 amd 平台。  但,從安全性,穩定度考慮不建議這樣去操作!!!

3. 64 位的客戶機只能運行在 64 宿主機之間的遷移,而 32 位客戶機可以在 32 宿主機和 64 位宿主機之間遷移。

4. 在進行動態遷移時,被遷移客戶機的名稱是唯一的,在目的宿主機上不能有與源宿主機被遷移客戶機同名的客戶機存在。

5. 目的宿主機和源宿主機的軟件盡可能的相同。也就是同為 Vmware , KVM , Xen 等。

 

 

七、v2v遷移實踐

安裝前准備工作:

遷移需要識別 source&target 主機的主機名所以需要我們搭建 DNS Ser 或者將 IP& 域名 & 主機名的對應條目寫入到 hosts 文件中去。

 

實驗環境:

Source Ser ---- VM

Target Ser

NFS Server 共享存儲服務器

 

實驗步驟:

1)首先在宿主機上配置NFS

第一步:下載

[root@ken ~]# yum install rpcbind nfs-utils -y

 

第二步:編輯配置文件

[root@ken ~]# vim /etc/exports   

    /nfsdate *(rw,sync)  

 

第三步:更改屬主

[root@ken ~]# chown -R nfsnobody: /nfsdate

 

第四步:啟動nfs

[root@ken ~]# systemctl restart rpcbind 
[root@ken ~]# systemctl restart nfs 

 

第五步:客戶端掛載使用

 [root@host1 ~]# yum install  nfs-utils -y 

[root@host1 ~]# showmount -e 192.168.5.5
[root@host1 ~]# mkdir /nfsdate                         
[root@host1 ~]# mount -t nfs 192.168.5.5:/nfsdate /nfsdate

 

 

3)冷遷移

 

virst list --all

cd /etc/libvirt/qemu

cp vm3.xml /root

virsh undefine vm3

cd /var/lib/libvirt/images/

mv vm3.qcow2 /nfsdate

cd /nfsdate

ls

cd /root

ls

vim vm3.xml

<source file='/nfsdate/vm3.qcow2'/>

virsh define vm3.xml

virsh list --all

virsh start vm3

virsh console vm3

 

 

4)熱遷移

1.首先進行鏈接

 

 

 

 

 

2.遷移

 

 

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM