convert script and interface changes

This commit is contained in:
Jeffrey Picard 2022-01-31 14:47:48 +00:00
parent 04c66eb7d6
commit 814f63ad22
2 changed files with 47 additions and 4 deletions

View file

@ -0,0 +1,40 @@
import os
import plyvel
from lbry.wallet.server.db.prefixes import HubDB, DB_PREFIXES
def main(db_dir: str):
old_path = os.path.join(db_dir, 'lbry-leveldb')
new_path = os.path.join(db_dir, 'lbry-rocksdb')
old_db = plyvel.DB(
old_path, create_if_missing=False, max_open_files=64,
)
db = HubDB(new_path, max_open_files=64)
try:
for prefix, cf in db.column_families.items():
cnt = 0
for shard_int in range(2**8):
shard_prefix = prefix + shard_int.to_bytes(1, byteorder='big')
with db._db.write_batch() as batch:
batch_put = batch.put
with old_db.iterator(prefix=shard_prefix, fill_cache=False) as it:
cnt_batch = 0
for k, v in it:
batch_put((cf, k), v)
cnt += 1
cnt_batch += 1
if cnt % 100_000 == 0:
print(f"wrote {cnt} {DB_PREFIXES(prefix).name} items")
if cnt_batch % 1_000_000 == 0:
print(f"cnt_batch {cnt_batch} flushing 1m items")
db._db.write(batch)
batch.clear()
finally:
old_db.close()
db.close()
if __name__ == "__main__":
main('/mnt/sdb/wallet_server/_data/')

View file

@ -1,5 +1,6 @@
import struct import struct
import typing import typing
import os
import rocksdb import rocksdb
from typing import Optional from typing import Optional
@ -15,15 +16,17 @@ class PrefixDB:
PARTIAL_UNDO_KEY_STRUCT = struct.Struct(b'>Q') PARTIAL_UNDO_KEY_STRUCT = struct.Struct(b'>Q')
def __init__(self, path, max_open_files=64, secondary_path='', max_undo_depth: int = 200, unsafe_prefixes=None): def __init__(self, path, max_open_files=64, secondary_path='', max_undo_depth: int = 200, unsafe_prefixes=None):
db_exists = os.path.exists(path)
column_family_options = { column_family_options = {
prefix.value: rocksdb.ColumnFamilyOptions() for prefix in DB_PREFIXES prefix.value: rocksdb.ColumnFamilyOptions() for prefix in DB_PREFIXES
} if secondary_path else {} } if secondary_path or db_exists else {}
self.column_families: typing.Dict[bytes, 'rocksdb.ColumnFamilyHandle'] = {} self.column_families: typing.Dict[bytes, 'rocksdb.ColumnFamilyHandle'] = {}
self._db = rocksdb.DB( options = rocksdb.Options(
path, rocksdb.Options(
create_if_missing=True, use_fsync=True, target_file_size_base=33554432, create_if_missing=True, use_fsync=True, target_file_size_base=33554432,
max_open_files=max_open_files if not secondary_path else -1 max_open_files=max_open_files if not secondary_path else -1
), secondary_name=secondary_path, column_families=column_family_options )
self._db = rocksdb.DB(
path, options, secondary_name='', column_families=column_family_options
) )
for prefix in DB_PREFIXES: for prefix in DB_PREFIXES:
cf = self._db.get_column_family(prefix.value) cf = self._db.get_column_family(prefix.value)