Here I’m gonna explain how to recover a datastore that has been deleted by accident.
In order to simulate the senario I delete my datastore that contains some VM files:
data:image/s3,"s3://crabby-images/49680/496807ecd83da798fd6003fe5e3585bbd059cc8c" alt=""
data:image/s3,"s3://crabby-images/9407b/9407be1d8ac96a2358f8d2d0dd66da77cd11f3ca" alt=""
Now just enable the ssh service on our ESXi host:
data:image/s3,"s3://crabby-images/4354e/4354e99ae3e44040fbf1f60a46f4799a398fff12" alt=""
And connect to the one of esxi host that already connected to that Datastore
data:image/s3,"s3://crabby-images/4206f/4206f8a354880b8b6f7167122af51040e713de65" alt=""
Go to the vSphere client and write down the location for the deleted datastore or storage device
data:image/s3,"s3://crabby-images/df12b/df12bd897f773b08cacf2769641cb670747666b5" alt=""
If we need to see a summary about our storage devices in CLI mode we can use :
offset="128 2048"; for dev in `esxcfg-scsidevs -l | grep "Console Device:" | awk {'print $3'}`; do disk=$dev; echo $disk;
partedUtil getptbl $disk; { for i in `echo $offset`; do echo "Checking offset found at $i:"; hexdump -n4 -s $((0x100000+(512*$i))) $disk; hexdump -n4 -s $((0x1300000+(512*$i))) $disk; hexdump -C -n 128 -s $((0x130001d + (512*$i))) $disk; done; } | grep -B 1 -A 5 d00d; echo "---------------------"; done
data:image/s3,"s3://crabby-images/1446f/1446f78f8a298fc42674028260cfc939035b379a" alt=""
Now we need to get some info about the our deleted storage device partition table:
partedUtil getptbl /vmfs/devices/disks/{Device identifier}
data:image/s3,"s3://crabby-images/68acf/68acf766d45294893cdd6f27bb614bb4a39819ad" alt=""
In next step we should define what is the begining and end of block in VMFS partition by issuing this command:
partedUtil getUsableSectors /vmfs/devices/disks/{Device identifier}
data:image/s3,"s3://crabby-images/58bbc/58bbcf7f453362b87614402aa2385fd0d6bc038a" alt=""
Now it’s time to set the a lable for the partition table:
partedUtil mklabel /vmfs/devices/disks/{Device identifier} gpt
data:image/s3,"s3://crabby-images/ccbb7/ccbb72952679e9db51d030e9734f8ff2c655f5db" alt=""
Then we need to create the partition table, but before that we need to get the GUID of a VMFS partition because we lost a VMFS partition, if it was a vSAN partition we would use a vSAN GUID from table below, we can get this info with this command:
partedUtil showGuids
data:image/s3,"s3://crabby-images/6b3af/6b3afb7977a51181d57f9a1cbafc9015ee97683b" alt=""
Now we create the partition table :
partedUtil setptbl /vmfs/devices/disks/{Device identifier} gpt "1 2048 {end block in VMFS partition} {Partition GUID} 0"
data:image/s3,"s3://crabby-images/64c08/64c0869080f727144e102539577a1b70fddee7dc" alt=""
Now we can run the vmkfstool command to mount the deleted Datastore, and rescan all the storage devices
vmkfstools -V
esxcli storage core adapter rescan --all
data:image/s3,"s3://crabby-images/e94f6/e94f6d60a2e60f6866ccee572f822b93fa4b0375" alt=""
Now we should check in vSphere client whether the datastore is back or not
data:image/s3,"s3://crabby-images/1fb34/1fb34b4ca09edbe2f601aaa9c16fa58224ebf9f1" alt=""
the Datastore is back but the size is not correct, for solving this issue we need to check the vmkernel log:
(it is better to open another ssh console and use tail command as follow and on the first console use vmksfstools -V to see the logs
data:image/s3,"s3://crabby-images/3b8cd/3b8cd64b53c0bb556d0270dbfbee35ac60c7e5cc" alt=""
Now we just add 2047 to the highlighted number and try to create the partition table with new end block :
167770079 + 2047 = 167772126
data:image/s3,"s3://crabby-images/45180/451803abf17d7b1a3433755e1fc31c4bd0676e0e" alt=""
And check again the datastore if the datastore is inaccessible still we can mount it
data:image/s3,"s3://crabby-images/04413/044132dcec1937a98a30ec6a47e1397b5d6968bf" alt=""
Now we have access to the data