diff --git a/hudi-sync/hudi-hive-sync/src/main/java/org/apache/hudi/hive/transaction/lock/HiveMetastoreBasedLockProvider.java b/hudi-sync/hudi-hive-sync/src/main/java/org/apache/hudi/hive/transaction/lock/HiveMetastoreBasedLockProvider.java index aeeccf906fe96..328c8666a3072 100644 --- a/hudi-sync/hudi-hive-sync/src/main/java/org/apache/hudi/hive/transaction/lock/HiveMetastoreBasedLockProvider.java +++ b/hudi-sync/hudi-hive-sync/src/main/java/org/apache/hudi/hive/transaction/lock/HiveMetastoreBasedLockProvider.java @@ -149,6 +149,7 @@ public void close() { try { if (lock != null) { hiveClient.unlock(lock.getLockid()); + lock = null; } Hive.closeCurrent(); } catch (Exception e) { @@ -197,6 +198,7 @@ private void acquireLockInternal(long time, TimeUnit unit, LockComponent lockCom // it is better to release WAITING lock, otherwise hive lock will hang forever if (this.lock != null && this.lock.getState() != LockState.ACQUIRED) { hiveClient.unlock(this.lock.getLockid()); + lock = null; } } }