博文大綱:vim
- 1、KVM虛擬機的遷移方式及須要注意的問題
- 2、kvm虛擬機熱遷移配置實例
KVM虛擬機的遷移有兩種方法:
一、靜態遷移(冷遷移):對於冷遷移,就是在虛擬機關閉狀態下,將虛擬機的磁盤文件及.xml配置文件(這兩個文件組成了一個虛擬機)複製到要遷移到的目標主機上,而後在目標主機上使用「virsh define *.xml」命令從新定義虛擬機便可。
二、動態遷移(熱遷移):對於熱遷移,比較經常使用,一般是這臺服務器上正在跑着一些業務,而這些業務又不容許中斷,那麼就須要使用熱遷移了,這篇博文將詳細寫出熱遷移的步驟。centos
一般咱們存放虛擬機磁盤的目錄都是掛在的一個nfs文件系統的磁盤,而這個磁盤一般是LVM文件系統。因此須要進行冷遷移時,只要在目標主機上掛載這個nfs文件系統,就能夠看到要遷移的那個虛擬機的磁盤文件,一般以.qcow2或.raw結尾的,而後,只需將虛擬機的.xml配置文件發送到目標服務器上,而後從新定義一下便可經過「virsh list --all」命令查看到遷移過來的虛擬機。服務器
若是源宿主機和目的宿主機共享存儲系統,則只須要經過網絡發送客戶機的 vCPU 執行狀
態、內存中的內容、虛機設備的狀態到目的主機上。不然,還須要將客戶機的磁盤存儲發到目的主
機上。共享存儲系統指的是源和目的虛機的鏡像文件目錄是在一個共享的存儲上的。網絡
在基於 共享存儲系統 時,KVM 動態遷移的具體過程爲:
一、遷移開始時,客戶機依然在宿主機上運行,與此同時,客戶機的內存頁被傳輸到目的主機上。
二、QEMU/KVM 會監控並記錄下遷移過程當中全部已被傳輸的內頁的任何修改,並在全部內存頁都傳輸完成後即開始傳輸在前面過程當中內存頁的更改內容。
三、QEMU/KVM 會估計遷移過程當中的傳輸速度,當剩餘的內存數據量可以在一個能夠設定的時間週期(默認 30 毫秒)內傳輸完成時,QEMU/KVM 會關閉源宿主機上的客戶機,再將剩餘的數據量傳輸到目的主機上,最後傳輸過來的內存內容在目的宿主機上恢復客戶機的運行狀態。
四、至此,KVM 的動態遷移操做就完成了。遷移後的客戶機儘量與遷移前一致,除非目的主機上缺乏一些配置,好比網橋等。注意,當客戶機中內存使用率很是大並且修改頻繁時,內存中數據不斷被修改的速度大於KVM可以傳輸的內存速度時,動態遷移的過程是完成不了的,這時候只能靜態遷移。ssh
不管是冷遷移仍是熱遷移,注意事項大都差很少。ide
遷移前目標服務器的要求以下:工具
- 最好遷移的服務器cpu品牌同樣;
- 64位只能在64位宿主機間遷移,32位能夠遷移32位和64位宿主機;
- 宿主機中的虛擬機名字不能衝突;
- 目的宿主機和源宿主機軟件配置儘量的相同,如 有相同的橋接網卡,資源池等;
- 兩臺遷移的主機 cat /proc/cpuinfo |grep nx 的設置是相同的NX,全名爲「No eXecute」,即「禁止運行」,是應用在CPU的一種技術,用做把存儲器區域分隔爲只供存儲處理器指令集,或只供數據使用。任何使用NX技術的存儲器,表明僅供數據使用,所以處理器的指令集並不能在這些區域存儲。這種技術可防止大多數的緩衝溢出,即一些惡意程序,把自身的惡意指令集放在其餘程序的數據存儲區並運行,從而把整臺計算機控制。
小結:測試
一、靜態遷移ui
- 拷貝鏡像文件和虛擬機配置文件;
- 從新定義此虛擬機。
二、動態遷移- 建立共享存儲;
- 兩臺機器掛載共享存儲(手工掛載;使用資源池);
- 啓動動態遷移;
- 建立遷移後的虛擬機配置文件;
- 從新定義虛擬機。
我這裏的環境以下:centos7
- 三臺Linux服務器,其中兩臺是KVM服務器,IP是192.168.20.2和192.168.20.3。一臺是NFS服務器,IP是192.168.20.4,用來作共享存儲(要求三臺服務器可互相ping通);
- 兩臺KVM虛擬機必須都有KVM環境。
我這的KVM環境是現成的,這裏就不展現了,若是沒有KVM環境,能夠參考博文:KVM虛擬化基礎管理進行搭建(很簡單,yum安裝一些包,啓動「libvirtd」服務便可,可能須要重啓服務器)。
nfs服務器192.168.20.4配置以下:
[root@nfs ~]# yum -y install nfs-utils rpcbind #安裝所需軟件包 [root@localhost ~]# systemctl enable nfs #設置NFS開機自啓 [root@localhost ~]# systemctl enable rpcbind #設置rpcbind開機自啓 [root@nfs ~]# mkdir -p /nfsshare #建立須要共享的目錄 [root@nfs ~]# vim /etc/exports #編輯NFS的配置文件,默認爲空 /nfsshare *(rw,sync,no_root_squash) #第一列表明共享的目錄 #第二列的星號表明容許全部網絡訪問; #rw表明讀寫權限;sync表明同步寫入磁盤; #no_root_squash表示當前客戶機以root身份訪問時賦予本地root權限 #(默認是root_squash,將做爲nfsnobody用戶對待),若不加no_root_squash, #可能會致使被降權,而沒法進行讀寫(wr)。 [root@nfs ~]# systemctl restart rpcbind #啓動該服務 [root@nfs ~]# systemctl restart nfs #啓動該服務 [root@nfs ~]# netstat -anpt | grep rpc #確認服務已啓動 [root@nfs ~]# showmount -e #查看本機共享的目錄 Export list for nfs: /nfsshare * [root@nfs ~]# firewall-cmd --add-service=rpc-bind --permanent [root@nfs ~]# firewall-cmd --add-service=nfs --permanent [root@nfs ~]# firewall-cmd --add-service=mountd --permanent [root@nfs ~]# systemctl restart firewalld #重啓防火牆,使配置生效
NFS服務器至此配置完成!!!
我這裏的遷移操做依賴於桌面圖形化環境,若須要使用命令遷移,能夠下載這個文檔進行參考,我沒有研究過使用命令遷移。
兩臺KVM服務器配置以下(兩臺kvm主機都須要進行下面的配置):
1.安裝rpcbind軟件包,並啓動rpcbind服務,爲了使用showmount查詢工具,因此將nfs-utils也一塊兒裝上:
[root@localhost ~]# yum -y install nfs-utils rpcbind [root@localhost ~]# systemctl enable rpcbind [root@localhost ~]# systemctl start rpcbind [root@kvm ~]# showmount -e 192.168.20.4 #查詢nfs服務器共享的目錄 Export list for 192.168.20.4: /nfsshare * [root@kvm ~]# mount -t nfs 192.168.20.4:/nfsshare /kvm/disk/ #進行掛載 [root@kvm ~]# df -hT /kvm/disk/ 文件系統 類型 容量 已用 可用 已用% 掛載點 192.168.20.4:/nfsshare nfs4 50G 33M 50G 1% /kvm/disk #在其中一臺服務器上寫入一個測試文件,看看在其餘服務器上是否能夠看到 [root@kvm1 ~]# touch /kvm/disk/test #在其中一個kvm服務器上建立測試文件 [root@kvm2 ~]# ls /kvm/disk #保證在第二臺kvm服務器的目錄下也能夠看到 test
至此,就保證了兩臺kvm服務器使用的目錄都是同一塊磁盤存儲的(注意:兩臺kvm虛擬機的掛載nfs文件系統的目錄路徑必須一致,我這裏兩臺kvm虛擬機都是掛載到了/kvm/disk/目錄下,不然會在後面的操做中發生錯誤)。
[root@kvm1 ~]# virt-manager #打開虛擬機控制檯
下面對話框中,目標路徑是KVM本機的「/kvm/disk」,主機名寫的是nfs服務器的IP地址,源路徑是nfs服務器共享的目錄。
以上操做一樣須要在第二臺KVM上進行操做,最好定義的存儲池名字等都一致。以避免發生沒必要要的麻煩。
:
自行上傳一個centos的iso系統文件,這裏須要指定要安裝的iso文件:
至此,正常的自行安裝虛擬機便可。
如下操做主要是爲了模擬虛擬機爲公網用戶提供服務中進行熱遷移。
1)kvm1操做以下:
[root@kvm ~]# systemctl stop NetworkManager #中止此服務 [root@kvm ~]# virsh iface-bridge ens33 br0 #執行此命令時,若提示如下信息,不用在乎,由於其已經存在了 使用附加設備 br0 生成橋接 ens33 失敗 已啓動橋接接口 br0 [root@kvm ~]# ls /etc/sysconfig/network-scripts/ | grep br0 ifcfg-br0 #肯定有此文件就行 [root@kvm ~]# virsh destroy centos7.0 #關閉新建的虛擬機 域 centos7.0 被刪除 [root@kvm ~]# virsh edit centos7.0 #編輯虛擬機的配置文件,定位到interface <interface type='bridge'> #將此處改成bridge <mac address='52:54:00:a9:cc:5f'/> #刪除Mac地址這行 <source bridge='br0'/> #將此處更改成這樣 #保存退出便可 [root@kvm1 ~]# virsh start centos7.0 域 centos7.0 已開始
開啓虛擬機後,配置虛擬機的網卡配置文件,默認網卡文件爲ifcfg-eth0:
重啓網絡服務,而且確認IP地址:
如今能夠在虛擬機上執行「ping www.baidu.com」 命令,使其持續ping公網。
2)kvm2操做以下:
[root@kvm ~]# systemctl stop NetworkManager #中止此服務 [root@kvm ~]# virsh iface-bridge ens33 br0 #執行此命令時,若提示如下信息,不用在乎,由於其已經存在了 使用附加設備 br0 生成橋接 ens33 失敗 已啓動橋接接口 br0 [root@kvm ~]# ls /etc/sysconfig/network-scripts/ | grep br0 ifcfg-br0 #肯定有此文件就行 #因爲kvm2沒有虛擬機,因此只需將網絡更改成橋接模式便可,。 #以上配置是爲了防止虛擬機遷移到這臺服務器後,沒法和公網進行聯繫。
1)kvm1服務器上進行如下操做:
[root@kvm1 ~]# virt-manager #打開虛擬機控制檯
填寫以下,填寫完成後,單擊「鏈接」:
會提示須要安裝如下軟件包:
進行安裝:
[root@kvm1 ~]# yum -y install openssh-askpass
根據彈出的對話框提示,輸入「yes」:
輸入目標主機的root密碼:
等待遷移完成,這個過程很快:
遷移完成:
如今去目標kvm服務器上,打開新遷移過去的虛擬機(會發現ping命令還在繼續,壓根就沒有中斷過):
能夠自行使用「virsh list --all」分別在兩臺kvm服務器上進行確認,這個虛擬機是否真的遷移到第二臺kvm服務器上了。
———————— 本文至此結束,感謝閱讀 ————————