LevelDB metadata corruption recovery


Corruption in the LevelDB metadata might happen due to a bad RAM-stick. In such cases you will encouter issues restarting the lotus-miner process again. The error log will look something similar to this:

  - leveldb/table: corruption on data-block (pos=1352397): checksum mismatch, want=0x972e02b got=0x43ac9dfa [file=xxxx.ldb]


  • Mainnet
  • Calibnet


First start by copying the corrupted metadata-folder to another location:

rclone copy -P .lotusminer/datastore/metadata ./oldmeta
Transferred:      218.913k / 218.913 kBytes, 100%, 80.787 MBytes/s, ETA 0s
Errors:                 0
Checks:                 0 / 0, -
Transferred:            7 / 7, 100%
Elapsed time:          0s

Then install plyvel, a Python interface to LevelDB.

pip install plyvel
Collecting plyvel
  Downloading plyvel-1.5.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (766 kB)
     |████████████████████████████████| 766 kB 27.2 MB/s 
Installing collected packages: plyvel
Successfully installed plyvel-1.5.0

Then we can write our Python program to recover the metadata. Type python3 and write the program in the promts:

Python 3.8.10 (default, Jun 22 2022, 20:18:18) 
[GCC 9.4.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import plyvel
>>> db = plyvel.DB('oldmeta')
>>> db2 = plyvel.DB('newmeta', create_if_missing=True)
>>> for key, v in db:
...     db2.put(key, v)
>>> db2.close()
>>> [exit]

You should now have a new folder called newmeta with the recovered metadata. Move the original and corrupted metadata to a backup location.

rclone move -P .lotusminer/datastore/metadata ./backup-meta

We can now move and rename the recovered metadata in the newmeta folder into the .lotusminer/datastore/ folder.

rclone move -P ./newmeta .lotusminer/datastore/metadata

You can now restart the lotus-miner process and see that it has been recovered.


These steps are only needed in cases where no proper metadata backup has been generated. It is adviced to setup proper automated backups of the metadata