本文主要以解決問題的方式給大家一個(在線)遷移虛擬機的方法,可能內容包含的不是很全面,這些只是我在實驗的時候遇到的問題,如果遇到的問題沒有被包含可以留言回復。。。
廢話不多說,直入正題(被遷移的機器成為:sourceVM,所在服務器:source,目標服務器:target,#後是shell命令)
實驗環境:
RedHat 6.2
復制代碼代碼如下: # virsh version
Compiled against library: libvir 0.9.4
Using library: libvir 0.9.4
Using API: QEMU 0.9.4
Running hypervisor: QEMU 0.12.1
主要用兩種方式,命令行virsh migrate 和圖形界面 virt-mamge
命令行比較簡單:
復制代碼代碼如下: #virsh migrate sourceVM qemu+ssh://target/system --live
(如果ssh的端口不是默認22,可以寫為 qemu+ssh://target:port/system)
No.1 Question::
error: internal error hostname on destination resolved to localhost, but migration requires an FQDN
解決辦法很簡單,因為默認情況下hostname 是 localhost,我們需要把目標的hostname修改一下,臨時的也可以。
復制代碼代碼如下: #hostname target
No.2 Question:
error: internal error Attempt to migrate guest to the same host 00020003-0004-0005-0006-000700080009
這個mail list 裡有大牛說是服務器提供商的問題
你可以用#dmidecode -s system-uuid 查看一下這個ID,理論上是#virsh sysinfo | grep uuid 及# virsh capabilities | grep uuid
這三個ID是一樣的。(之前看論壇裡發的解決方法是需要下載一個dmidecode 命令的文件去替換系統的,達到修改的目的,不過今天我只是修改了libvirt的配置文件就可以了,可能是版本的問題)
我們修改一下libvirtd的配置文件
復制代碼代碼如下: #sed -i "/#host_uuid/ahost_uuid = \"`uuidgen`\"" /etc/libvirt/libvirtd.conf
重啟一下libvirtd 服務
復制代碼代碼如下: # /etc/init.d/libvirtd restart
然後再查看一下
復制代碼代碼如下: # virsh capabilities | grep uuid
No.3 Question:
error: unable to set user and group to '107:107' on '/image/sourceVM/disk.img': No such file or directory
如果順利進入到這步的話,就很簡單了,沒有directory 直接創建一個就可以
注:創建的磁盤應該和源虛擬機的磁盤是一樣的大小(更大應該是可以)和格式(raw還是qcow2)
No.4 Question::
error: Unable to resolve address 'target' service '49155': Name or service not known
《《Name or service not known》》這個相信大家都知道如何解決,/etc/hosts ...略過
再次執行遷移命令的時候,就基本不會報錯了,我的實驗環境是,如果你還有其他問題,請貼圖回復,謝謝
虛擬機遷移和網絡的帶寬、虛擬機鏡像的大小有直接關系,但是在線遷移最關心的應該是宕機時間,我測試的方法是一直ping target 服務器,大概停頓1s。
圖形就比較簡單了,處理上邊所說的相同的FQDN,相同的UUID以外,就是建立連接時的ssh認證問題。
我這邊的環境是必須要在使用virt-manage遠程連接的時候添加ssh的認證,而且還要在終端登陸一次,使服務器的信息記錄到目標機器的~/.ssh/knows 下(其實就是有一個yes/no的界面 輸入yes即可)
建立連接以後,選中機器右鍵有一個Migrate的選項
彈出遷移的目標服務器,選擇目標服務器,點擊Migrate即可
遷移的問題大概就這麼多。
剩下的是一些有關於遷移和其他的小細節:
在設置vnc監聽端口時基本上有3種,
127.0.0.1 (默認):只有本機能訪問,也就是virt-mange和virt-view
host_ip :除了本機的所有機器都可以訪問
0.0.0.0: 以上兩種的合集
在遷移時,需要把監聽地址改為0.0.0.0,端口為-1 自動分配,因為如果不出意外的話,指定的端口會沖突!!!
如果沒有.ssh/這個目錄,可能做不了免認證(沒有真實環境,不知道原因),沒關系,我們可以用tcp代替ssh連接到目標服務器上。
方法如下:
1 修改/etc/libvirt/libvirtd.conf中
[/code] listen_tls = 0
listen_tcp = 1
tcp_port = "16509"
auth_tcp = "sasl"[/code]
2 去掉/etc/sysconfig/libvirtd 中LIBVIRTD_ARGS="--listen" 的注釋
3 修改/etc/libvirt/qemu.conf 中listen 為0.0.0.0 ,去掉password注釋
4 運行以下命令可以添加用戶
復制代碼代碼如下: # saslpasswd2 -a libvirt admin
Password: xxxxxx
Again (for verification): xxxxxx
通過以下命令可以查看已經創建的用戶
復制代碼代碼如下: # sasldblistusers2 -f /etc/libvirt/passwd.db
[email protected]: userPassword
5 重啟libvirtd 服務 ok!
原文引用:xiaoli110 的BLOG
在的ssh的位置選擇tcp,如果端口沒有修改可以不填端口
測試連接的時候可以用 #virsh -c qemu+tcp://target/system list
還有一個問題是,遷移的時候可以拉服務器嗎?正常的遷移時大多是推過去的,就想scp 和rsync一樣,以拉虛擬機的方式遷移是可以的
遷移虛擬機對服務器的要求,之前看必須是兩個相同的Cpu才可以,今天我測試的時候是發現可以從source遷移到target,回來就出問題了,發現時 sourcce 少了一些指令集,所以可以說不通的cpu也是可以做遷移的,只是目標服務器必須包含源服務器cpu的所有指令集。