问题背景:
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