问题背景:

1、一台虚拟机,创建了三份快照。在一次维护过程中,把快照全部删除(合并快照,保持当前最新状态),同时关闭虚拟机。

由于快照较多,还没有全部合并完成,虚拟机已经关机了。

2、重新打开虚拟机时提示开机失败,提示大概意思是找不到之前的快照文件,无法开机。

3、打开存储管理器,原始vmdk文件、000001.vmdk 、000002.vmdk 000003.vmdk文件都在,虚拟机当前所使用的硬盘对应000002.vmdk。

4、重新装载虚拟机,只能选择原始vmdk作为硬盘,无法选择其他vmdk作为硬盘,如果挂载原始盘,虚机只回到没有做任何快照时候的状态,后期的数据全部丢失。

解决步骤:

登录到ESX主机,进入虚机所在的文件目录,有以下多个文件:

abc.-000001-delta.vmdk

abc.-000001.vmdk

abc.-000002-delta.vmdk

abc.-000002.vmdk

abc.-000003-delta.vmdk

abc.-000003.vmdk

abc.-flat.vmdk

abc..vmdk

abc.vmx

... ...

1、#grep -i filename abc.vmx 查看当前虚拟机挂载哪些硬盘,结果如下:

scsi0:0.fileName="abc.-000002.vmdk" //当前硬盘为0002.vmdk;

2、#cat abc.-00002.vmdk 查看00002硬盘的父盘是哪一块,信息如下:

CID=929c1b7d //此硬盘的编号

parentCID=9b5a6f9f //父盘的编号

parentFileNameHint="abc.-000001.vmdk" //父盘对应的硬盘

3、找到并打开上面的父盘(000001)信息

#cat abc.-000001.vmdk,结果如下:

CID=9b5a6f9f //此硬盘的编号

parentCID=9b5a6f9f//父盘的编号,此处9b5a6f9f信息已经混乱了

parentFileNameHint="abc.-000003.vmdk" //父盘对应的硬盘

4、忽略混乱错误,找到并打开-000003.vmdk ,

#cat abc.-000003.vmdk,结果如下:

CID=9b5a6f9f //此硬盘的编号,混乱,和子盘重复

parentCID=014617b2//父盘的编号,混乱,

parentFileNameHint="abc..vmdk" //父盘对应的硬盘

5、打开.vmdk,

#cat abc..vmdk,结果如下:

CID=95bd0757//此硬盘的编号,此盘没有子盘,所以提示找不到快照所对应的硬盘!

parentCID=ffffffff //没有父盘,此盘为最原始的盘。

6、按照vmware文档的要求,正常情况下用vmkfstools将原始盘克隆一个新的硬盘,然后将新硬盘挂载到空的虚机上,应该能够解决问题。

#mkdir recover

#vmkfstools -i abc..vmdk recover/newdisk.vmdk

运行会显示:

Destination disk format :VMFS thick

Coloning disk 'abc..vmdk'...

Clone: 100% done。

由于编号混乱,如果对..vmdk克隆,所得到的硬盘和原始盘一样;如果对000001或000002、000003.vmdk进行克隆,提示当创建子盘的时候,父盘已经被修改过了,无法克隆。

7、如果人为按照上述逻辑,修改每块硬盘的CID号和父盘的CID号,得到的克隆盘挂载、开机后显示硬盘损坏。

8、考虑到当前虚拟机的硬盘为000002.vmdk,正常的快照合并时,应该先将3合并到2,再将2合并到1,再将1合并到原始盘,只是合并到2的时候就关机了,所以编号混乱。按照此思路,修改000001.vmdk文件,

将父盘CID(9b5a6f9f)修改为原始盘的CID(95bd0757),并将parentFileNameHint直接指向到原始盘..vmdk,修改后的000001.vmdk信息如下:

CID=9b5a6f9f 

parentCID=95bd0757

parentFileNameHint="abc..vmdk" 

9、按照上述方式,果然回到最新状态,只不过打开虚拟后里面的部分文件夹损坏,这次运气比较好话,最重要的几个文件和数据库是最新的,有些文件夹无法打开,比原始盘的效果更好了。

 

原文地址:http://blog.sina.com.cn/s/blog_4ce6566f0100hafm.html