From 0804ea94f17a87b2ffa7f9d265e7ae641b89e332 Mon Sep 17 00:00:00 2001 From: s-a-tanjim Date: Mon, 26 Aug 2024 22:38:29 +0600 Subject: [PATCH 1/2] Test --- src/keri/db/dbing.py | 1 + 1 file changed, 1 insertion(+) diff --git a/src/keri/db/dbing.py b/src/keri/db/dbing.py index bd2db031..2d045a6c 100644 --- a/src/keri/db/dbing.py +++ b/src/keri/db/dbing.py @@ -381,6 +381,7 @@ def reopen(self, readonly=False, **kwa): # open lmdb major database instance # creates files data.mdb and lock.mdb in .dbDirPath + print(f"Opening DB with map size: {self.MapSize}") self.env = lmdb.open(self.path, max_dbs=self.MaxNamedDBs, map_size=self.MapSize, mode=self.perm, readonly=self.readonly) self.opened = True if opened and self.env else False From 1454600359b6395e4641b7486c842d06ad556269 Mon Sep 17 00:00:00 2001 From: s-a-tanjim Date: Mon, 26 Aug 2024 23:12:36 +0600 Subject: [PATCH 2/2] Test2 --- src/keri/db/dbing.py | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/src/keri/db/dbing.py b/src/keri/db/dbing.py index 2d045a6c..62a2b40f 100644 --- a/src/keri/db/dbing.py +++ b/src/keri/db/dbing.py @@ -59,8 +59,11 @@ from hio.base import filing +from .. import help from ..help import helping +logger = help.ogler.getLogger() + ProemSize = 32 # does not include trailing separator MaxProem = int("f"*(ProemSize), 16) MaxON = int("f"*32, 16) # largest possible ordinal number, sequence or first seen @@ -68,6 +71,8 @@ SuffixSize = 32 # does not include trailing separator MaxSuffix = int("f"*(SuffixSize), 16) +KERIDBMapSizeKey = "KERI_DB_MAP_SIZE" + def dgKey(pre, dig): """ Returns bytes DB key from concatenation of '.' with qualified Base64 prefix @@ -381,7 +386,13 @@ def reopen(self, readonly=False, **kwa): # open lmdb major database instance # creates files data.mdb and lock.mdb in .dbDirPath - print(f"Opening DB with map size: {self.MapSize}") + if (mapSize := os.getenv(KERIDBMapSizeKey)) is not None: + try: + self.MapSize = int(mapSize) + except ValueError: + logger.error("KERI_DB_MAP_SIZE must be an integer value >1!") + raise + self.env = lmdb.open(self.path, max_dbs=self.MaxNamedDBs, map_size=self.MapSize, mode=self.perm, readonly=self.readonly) self.opened = True if opened and self.env else False