好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > Linux系統中關于KVM虛擬機遷移的一些相關問題

Linux系統中關于KVM虛擬機遷移的一些相關問題

熱門標簽:北京市地圖標注 焦作人工智能電話機器人軟件 2020電銷機器人排行 鹽城客服外呼系統軟件 淘寶系統退貨外呼項目考試答案 鄭州營銷外呼系統運營商 廳外呼梯系統布線 百度地圖標注陰影動態 貴陽語音電銷機器人招商

本文主要以解決問題的方式給大家一個(在線)遷移虛擬機的方法,可能內容包含的不是很全面,這些只是我在實驗的時候遇到的問題,如果遇到的問題沒有被包含可以留言回復。。。

廢話不多說,直入正題(被遷移的機器成為: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
fred@t60wlan.home.berrange.com: userPassword
 
5 重啟libvirtd 服務 ok!
原文引用:xiaoli110 的BLOG

在的ssh的位置選擇tcp,如果端口沒有修改可以不填端口
測試連接的時候可以用 #virsh -c qemu+tcp://target/system list

還有一個問題是,遷移的時候可以拉服務器嗎?正常的遷移時大多是推過去的,就想scp 和rsync一樣,以拉虛擬機的方式遷移是可以的

遷移虛擬機對服務器的要求,之前看必須是兩個相同的Cpu才可以,今天我測試的時候是發現可以從source遷移到target,回來就出問題了,發現時 sourcce 少了一些指令集,所以可以說不通的cpu也是可以做遷移的,只是目標服務器必須包含源服務器cpu的所有指令集。

標簽:馬鞍山 淮安 和田 法律問答 湖南 和田 開封 石家莊

巨人網絡通訊聲明:本文標題《Linux系統中關于KVM虛擬機遷移的一些相關問題》,本文關鍵詞  Linux,系統,中,關于,KVM,虛擬機,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Linux系統中關于KVM虛擬機遷移的一些相關問題》相關的同類信息!
  • 本頁收集關于Linux系統中關于KVM虛擬機遷移的一些相關問題的相關信息資訊供網民參考!
  • 推薦文章