利用-flat.vmdk檔案恢復ESXI虛擬機器的vmdk檔案

安全劍客發表於2019-08-11
錯誤描述

在vSphere上,一次重啟虛擬伺服器時出現啟動不了,提示找不到vmdk虛擬磁碟檔案
利用-flat.vmdk檔案恢復ESXI虛擬機器的vmdk檔案利用-flat.vmdk檔案恢復ESXI虛擬機器的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磁碟檔案,所以只要這個檔案還存在,就可以恢復。


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31559985/viewspace-2653305/,如需轉載,請註明出處,否則將追究法律責任。

相關文章