利用-flat.vmdk檔案恢復ESXI虛擬機器的vmdk檔案
錯誤描述
在vSphere上,一次重啟虛擬伺服器時出現啟動不了,提示找不到vmdk虛擬磁碟檔案
原因分析
檢視這臺虛擬伺服器的摘要資訊,對比datastore上其他可用的虛擬機器,發現損壞的伺服器上確實缺少一個vmdk磁碟檔案,但是可以看見一個50G的xxx-flat.vmdk檔案;而正常的伺服器只有xxx.vmdk,沒有xxx-flat.vmdk,關機之後兩個檔案都存在,而且真實的磁碟容量從vmdk轉移到了xxx-flat.vmdk。
虛擬主機在執行的時候,實際在使用的是xxx-flat.vmdk,然而xxx.vmdk是可以同時被刪除的,才導致了問題。
這裡需要說明,虛擬機器的每個磁碟驅動器都包含了一對.vmdk檔案。一個是文字檔案,包含了關於虛擬硬碟的描述資料;另外一個是磁碟的實際內容。例如,一個名為examplevm的虛擬機器連線有一個硬碟。這個磁碟由如下兩個檔案構成:一個小於 1KB 的examplevm.vmdk描述檔案和一個10GB大小的examplevm- flat.vmdk平面(資料)檔案,該檔案包含虛擬機器的實際資料,而這些資料又是以二進位制的形式存放在物理磁碟上,examplevm.vmdk描述檔案就是描述這種對映關係的。.
解決辦法
1) 用ssh登入vsphere主機,查詢xxx-flat.vmdk檔案所在的位置以及目錄,並記錄檔案的大小
~ # find / -name "新建虛擬機器-flat.vmdk" /vmfs/volumes/50a98441-ab02c8b7-e60a-001517712dce/新建虛擬機器/新建虛擬機器-flat.vmdk ~ # ls -l /vmfs/volumes/50a98441-ab02c8b7-e60a-001517712dce/新建虛擬機器/新建虛擬機器-flat.vmdk -rw------- 1 root root 53687091200 Apr 16 09:13 /vmfs/volumes/50a98441-ab02c8b7-e60a-001517712dce/新建虛擬機器/新建虛擬機器-flat.vmdk
注意,ESXi5預設沒有開啟ssh,需要通過vsphere client登入伺服器,【配置】【安全配置檔案】【服務-屬性】手動開啟。
2) 重新命名xxx-flat.vmdk檔案
~# cd /vmfs/volumes/50a98441-ab02c8b7-e60a-001517712dce/新建虛擬機器/ /vmfs/volumes/50a98441-ab02c8b7-e60a-001517712dce/新建虛擬機器_1 # mv 新建虛擬機器-flat.vmdk tmp_新建虛擬機器-flat.vmdk /vmfs/volumes/50a98441-ab02c8b7-e60a-001517712dce/新建虛擬機器 # ls -la drwxr-xr-x 1 root root 1680 Apr 21 05:47 . drwxr-xr-t 1 root root 2660 Apr 18 03:16 .. -rw-r--r-- 1 root root 102076 Apr 18 10:05 vmware.log -rw------- 1 root root 96468992 Apr 18 05:43 vmx-新建虛擬機器-578288005-1.vswp -rw------- 1 root root 2147483648 Apr 18 05:43 新建虛擬機器-2277f985.vswp -rw------- 1 root root 53687091200 Apr 21 05:47 新建虛擬機器-flat.vmdk -rw------- 1 root root 8684 Apr 21 05:47 新建虛擬機器.nvram -rw------- 1 root root 503 Apr 18 05:44 新建虛擬機器.vmdk -rw-r--r-- 1 root root 0 Apr 16 09:13 新建虛擬機器.vmsd -rwxr-xr-- 1 root root 3690 Apr 18 05:43 新建虛擬機器.vmx -rw------- 1 root root 0 Apr 18 05:43 新建虛擬機器.vmx.lck -rwxr-xr-- 1 root root 3690 Apr 18 05:43 新建虛擬機器.vmx~
3) 在虛擬機器目錄下建立xxx.vmdk檔案,大小要和xxx-flat.vmdk一樣大
/vmfs/volumes/50a98441-ab02c8b7-e60a-001517712dce/新建虛擬機器 # vmkfstools -c 53687091200 -a lsilogic 新建虛擬機器.vmdk Create: 100% done. /vmfs/volumes/50a98441-ab02c8b7-e60a-001517712dce/新建虛擬機器 # ls -la *vmdk -rw------- 1 root root 53687091200 Apr 21 05:49 新建虛擬機器-flat.vmdk -rw------- 1 root root 503 Apr 18 05:44 新建虛擬機器.vmdk
4) 將原來的(tmp_)xxx-flat.vmdk覆蓋掉剛建立的同樣大小的xxx-flat.vmdk
/vmfs/volumes/50a98441-ab02c8b7-e60a-001517712dce/新建虛擬機器 # mv tmp_新建虛擬機器-flat.vmdk 新建虛擬機器-flat.vmdk
重新命名操作很快完成,啟動虛擬機器既可以恢復。(改完名後新建虛擬機器-flat.vmdk檔案就不見了)
總結
相比重新建立一個同名虛擬機器,然後mv原來的xxx-flat.vmdk硬碟檔案到新的虛擬機器,更節省時間;此外也無需再次配置網絡卡地址。
xxx.vmdk本身是一個不到1k的文字檔案,通過vi編輯檢視可知真正存放資料的是xxx-flat.vmdk磁碟檔案,所以只要這個檔案還存在,就可以恢復。