As part of CICD Approach multiple applications are deployed at once in a kubernetes cluster as pods . Applicstions update databases using liquibase update.
Sometime one or more applications work on same database with ownership on different tables. Since changelog and changeloglock is common across a database, if one application acquires a lock, other applications waits for lock for time defined in changelog-lock-wait-time-in-minutes . This works fine until the application that acquired lock, releases the lock. Unfortunately due to some other timeouts like k8s probes, restarts the pod based on its timeout., the lock is not released and pod goes away, other applications wait until the lock is manually cleared.
Is there a way that lock can exist only certain period of time, like 15 20 mins from the time it is granted.