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