mirror of
https://github.com/waku-org/nwaku.git
synced 2025-02-28 23:10:54 +00:00
feat(store): vacuum after delete (#928)
This commit is contained in:
parent
aff3a8386c
commit
a9c31b4b53
@ -63,6 +63,11 @@ proc deleteOldest(db: WakuMessageStore): MessageStoreResult[void] =
|
|||||||
let numMessages = messageCount(db.database).get() # requires another SELECT query, so only run in debug mode
|
let numMessages = messageCount(db.database).get() # requires another SELECT query, so only run in debug mode
|
||||||
debug "Oldest messages deleted from DB due to overflow.", storeCapacity=db.storeCapacity, maxStore=db.storeMaxLoad, deleteWindow=db.deleteWindow, messagesLeft=numMessages
|
debug "Oldest messages deleted from DB due to overflow.", storeCapacity=db.storeCapacity, maxStore=db.storeMaxLoad, deleteWindow=db.deleteWindow, messagesLeft=numMessages
|
||||||
|
|
||||||
|
# reduce the size of the DB file after the delete operation. See: https://www.sqlite.org/lang_vacuum.html
|
||||||
|
let resVacuum = db.database.query("vacuum", proc(s: ptr sqlite3_stmt) = discard)
|
||||||
|
if resVacuum.isErr:
|
||||||
|
return err("vacuum after delete was not successful: " & resVacuum.error)
|
||||||
|
|
||||||
ok()
|
ok()
|
||||||
|
|
||||||
proc init*(T: type WakuMessageStore, db: SqliteDatabase, storeCapacity: int = 50000): MessageStoreResult[T] =
|
proc init*(T: type WakuMessageStore, db: SqliteDatabase, storeCapacity: int = 50000): MessageStoreResult[T] =
|
||||||
|
Loading…
x
Reference in New Issue
Block a user