Блокировка «элементов» предоставляется в качестве расширения на стороне клиента в Java SDK, вам нужно проделать определенную работу, чтобы фактически использовать его.
Причина этого заключается в распределенной природеДинамо БД.Обратите внимание, что блокировка не является классической блокировкой на основе строк на стороне сервера.Блокировка должна выполняться клиентами, использующими связанные «элементы».
Класс на стороне клиента для управления блокировкой называется «AmazonDynamoDBLockClient».Если вы ищете этот класс, вы найдете примеры его использования от разработчиков Amazon SDK.
Что нужно сделать с ним:
- Добавить глобальный идентификатор для блокировки вспросите перед написанием «элемента»
- Сообщите автору о блокировках и запретите запись в случае, если она «активна»
- Тайм-аут блокировки, так что в случае смерти клиента блокировка снимается
Взятый прямо из такого примера:
//build a lock client. any other client _not_ using this _same_ lock
//can still modify the data! this is not 'safe' in this regard!
final AmazonDynamoDBLockClient client = new AmazonDynamoDBLockClient(
AmazonDynamoDBLockClientOptions.builder(dynamoDB, "customLockTable")
.withTimeUnit(TimeUnit.SECONDS)
.withLeaseDuration(100L)
.withHeartbeatPeriod(40L)
.withCreateHeartbeatBackgroundThread(createHeartbeatBackgroundThread)
.build());
//try to acquire a lock on the partition key "FirstPart"
//of course this can fail, since someone else could have the lock
final Optional<LockItem> lockItem =
client.tryAcquireLock(AcquireLockOptions.builder("FirstPart").build());
Чтобы вышеприведенный код работал, вам нужно создать специальный 'customLockTable', он не является частью серверной части БД.природа.Поэтому приведенный выше пример неполон!