chore: postgres_driver - acquire/release advisory lock when creating partitions (#2784)

This commit is contained in:
Ivan FB 2024-06-07 17:54:26 +02:00 committed by GitHub
parent 005349ccfe
commit c5d19c4491
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -883,7 +883,7 @@ proc acquireDatabaseLock*(
proc releaseDatabaseLock*( proc releaseDatabaseLock*(
s: PostgresDriver, lockId: int = 841886 s: PostgresDriver, lockId: int = 841886
): Future[ArchiveDriverResult[void]] {.async.} = ): Future[ArchiveDriverResult[void]] {.async.} =
## Acquire an advisory lock (useful to avoid more than one application running migrations at the same time) ## Release an advisory lock (useful to avoid more than one application running migrations at the same time)
let unlocked = ( let unlocked = (
await s.getStr( await s.getStr(
fmt""" fmt"""
@ -930,6 +930,16 @@ proc addPartition(
"CREATE TABLE IF NOT EXISTS " & partitionName & " PARTITION OF " & "CREATE TABLE IF NOT EXISTS " & partitionName & " PARTITION OF " &
"messages FOR VALUES FROM ('" & fromInNanoSec & "') TO ('" & untilInNanoSec & "');" "messages FOR VALUES FROM ('" & fromInNanoSec & "') TO ('" & untilInNanoSec & "');"
# Lock the db
(await self.acquireDatabaseLock()).isOkOr:
error "failed to acquire lock", error = error
return err("failed to lock the db")
defer:
(await self.releaseDatabaseLock()).isOkOr:
error "failed to release lock", error = error
return err("failed to unlock the db.")
(await self.performWriteQuery(createPartitionQuery)).isOkOr: (await self.performWriteQuery(createPartitionQuery)).isOkOr:
if error.contains("already exists"): if error.contains("already exists"):
debug "skip create new partition as it already exists: ", skipped_error = $error debug "skip create new partition as it already exists: ", skipped_error = $error