问题背景:1、一台虚拟机,创建了三份快照。在一次维护过程中,把快照全部删除(合并快照,保持当前最新状态),同时关闭虚拟机。由于快照较多,还没有全部合并完成,虚拟机已经关机了。2、重新打开虚拟机时提示开机失败,提示大概意思是找不到之前的快照文件,无法开机。3、打开存储管理器,原始vmdk文件、000001.vmdk 、000002.vmdk 000003.vmdk文件都在,虚拟机当前所使用的硬盘对应000002.vmdk。4、重新装载虚拟机,只能选择原始vmdk作为硬盘,无法选择其他vmdk作为硬盘,如果挂载原始盘,虚机只回到没有做任何快照时候的状态,后期的数据全部丢失。解决步骤:登录到ESX主机,进入虚机所在的文件目录,有以下多个文件:abc.-000001-delta.vmdkabc.-000001.vmdkabc.-000002-delta.vmdkabc.-000002.vmdkabc.-000003-delta.vmdkabc.-000003.vmdkabc.-flat.vmdkabc..vmdkabc.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 thickColoning 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=95bd0757parentFileNameHint="abc..vmdk" 9、按照上述方式,果然回到最新状态,只不过打开虚拟后里面的部分文件夹损坏,这次运气比较好话,最重要的几个文件和数据库是最新的,有些文件夹无法打开,比原始盘的效果更好了。
|