昨天发布,今天早上来公司,发现线上有台vm镜像损坏,vhd-util check -n xxx 之后,报错“failed to get batmap header”
正好前段时间研究tapdisk2的时候,顺便看了vhd的文件格式,及一些元数据处理函数。
在libvhd.c里面加了一些调试信息,定位到checksum不对。心中暗喜,还好不是数据丢了,只是batmap的问题
解决办法就是把block的bitmap和batmap,对比,检查哪个batmap没更新
由于代码很久没碰了,生疏了,花了一下午时间,才搞定了,最后代码分析的结果是batmap和bitmap完全对应
看来就是在最后回写到文件的时候,batmap header,没有成功,导致里面的checksum没更新成功。
把最新的checksum更新到文件中,vhd-util check -n xxx后,得到“xxx is valid”
哎,一下午的时间就折腾这个小破文件了,我勒个去啊。