From f2434ca24b3581e4572708f4fe73b431afea4c59 Mon Sep 17 00:00:00 2001 From: Kirill Kurdyukov Date: Fri, 8 Nov 2024 17:29:18 +0300 Subject: [PATCH 1/2] feat: prepare hibernate release --- hibernate-dialect/CHANGELOG.md | 4 ++++ hibernate-dialect/pom.xml | 2 +- 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/hibernate-dialect/CHANGELOG.md b/hibernate-dialect/CHANGELOG.md index 87c003e..e7ec4e7 100644 --- a/hibernate-dialect/CHANGELOG.md +++ b/hibernate-dialect/CHANGELOG.md @@ -1,3 +1,7 @@ +## 1.2.0 ## + +- Added custom decimal jdbc codes `DECIMAL_31_9`, `DECIMAL_35_0`, `DECIMAL_35_9` + ## 1.1.0 ## - Added hint for scan queries diff --git a/hibernate-dialect/pom.xml b/hibernate-dialect/pom.xml index 3c8e9d7..9d39fba 100644 --- a/hibernate-dialect/pom.xml +++ b/hibernate-dialect/pom.xml @@ -6,7 +6,7 @@ tech.ydb.dialects hibernate-ydb-dialect - 1.1.0 + 1.2.0 jar From 7682a1d1a092f9b7db3bae32b0aaf9afe2b141e8 Mon Sep 17 00:00:00 2001 From: Kirill Kurdyukov Date: Thu, 14 Nov 2024 19:59:28 +0300 Subject: [PATCH 2/2] feat: micro fix --- .../YdbCoordinationServiceLockProvider.java | 26 +++++++++++++++---- 1 file changed, 21 insertions(+), 5 deletions(-) diff --git a/shedlock-ydb/src/main/java/tech/ydb/lock/provider/YdbCoordinationServiceLockProvider.java b/shedlock-ydb/src/main/java/tech/ydb/lock/provider/YdbCoordinationServiceLockProvider.java index d198486..4ef66c6 100644 --- a/shedlock-ydb/src/main/java/tech/ydb/lock/provider/YdbCoordinationServiceLockProvider.java +++ b/shedlock-ydb/src/main/java/tech/ydb/lock/provider/YdbCoordinationServiceLockProvider.java @@ -16,6 +16,7 @@ import tech.ydb.coordination.CoordinationSession; import tech.ydb.coordination.SemaphoreLease; import tech.ydb.coordination.settings.CoordinationSessionSettings; +import tech.ydb.coordination.settings.DescribeSemaphoreMode; import tech.ydb.core.Result; import tech.ydb.jdbc.YdbConnection; @@ -64,12 +65,27 @@ public Optional lock(LockConfiguration lockConfiguration) { var statusCS = coordinationSession.connect().join(); if (!statusCS.isSuccess()) { - logger.info("Failed creating coordination session [{}]", coordinationSession); + logger.warn("Failed creating coordination session [{}]", coordinationSession); return Optional.empty(); } - logger.info("Created coordination node session [{}]", coordinationSession); + logger.debug("Created coordination node session [{}]", coordinationSession); + + var describeResult = coordinationSession.describeSemaphore( + lockConfiguration.getName(), + DescribeSemaphoreMode.WITH_OWNERS + ).join(); + + if (describeResult.isSuccess()) { + var describe = describeResult.getValue(); + + if (!describe.getOwnersList().isEmpty()) { + var describePayload = new String(describe.getOwnersList().get(0).getData(), StandardCharsets.UTF_8); + + logger.info("Received DescribeSemaphore[Name={}, Data={}]", describe.getName(), describePayload); + } + } Result semaphoreLease = coordinationSession.acquireEphemeralSemaphore( lockConfiguration.getName(), @@ -81,12 +97,12 @@ public Optional lock(LockConfiguration lockConfiguration) { logger.debug(coordinationSession.toString()); if (semaphoreLease.isSuccess()) { - logger.info("Instance[{}] acquired semaphore[SemaphoreName={}]", instanceInfo, + logger.debug("Instance[{}] acquired semaphore [SemaphoreName={}]", instanceInfo, semaphoreLease.getValue().getSemaphoreName()); return Optional.of(new YdbSimpleLock(semaphoreLease.getValue(), instanceInfo, coordinationSession)); } else { - logger.info("Instance[{}] did not acquire semaphore", instanceInfo); + logger.debug("Instance[{}] did not acquire semaphore", instanceInfo); return Optional.empty(); } @@ -96,7 +112,7 @@ private record YdbSimpleLock(SemaphoreLease semaphoreLease, String metaInfo, CoordinationSession coordinationSession) implements SimpleLock { @Override public void unlock() { - logger.info("Instance[{}] released semaphore[SemaphoreName={}]", metaInfo, semaphoreLease.getSemaphoreName()); + logger.info("Instance[{}] released semaphore [SemaphoreName={}]", metaInfo, semaphoreLease.getSemaphoreName()); semaphoreLease.release().join();